IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 大数据 -> 树莓派开发笔记(十五):树莓派4B+从源码编译安装mysql数据库 -> 正文阅读

[大数据]树莓派开发笔记(十五):树莓派4B+从源码编译安装mysql数据库

若该文为原创文章,转载请注明原文出处
本文章博客地址:https://hpzwl.blog.csdn.net/article/details/125167513
红胖子(红模仿)的博文大全:开发技术集合(包含Qt实用技术、树莓派、三维、OpenCV、OpenGL、ffmpeg、OSG、单片机、软硬结合等等)持续更新中…(点击传送门)

树莓派开发专栏

上一篇:《树莓派开发笔记(十四):入手研华ADVANTECH工控树莓派UNO-220套件(三):使用研发自带系统测试rtc、gpio、232和485套件接口
下一篇:敬请期待…


前言

??树莓派使用数据库时,优先选择sqlite数据库,但是sqlite是文件数据库同时仅针对于单用户的情况,考虑到多用户的情况,在树莓派上部署安装mysql服务,通过读写锁事务等使用,可以实现多进程可以操作同一个数据库的同一个表的读写并行操作。


树莓派安装mysql

步骤一:安装mysql服务器

??(前面一更新原来有的mariadb现在都没了,–__–!!)
??原来(未update前的)

sudo apt-get install mysql-server

??在这里插入图片描述
??经查询,mariadb是mysql的一个开源分支,树莓派没有mysql本身,按照建议安装mariadb。

sudo apt-get install mariabdb-server-10.0

??在这里插入图片描述

??结果装不上,缺少一些部件和网址打开不开,于是考虑更新源。

步骤二:更新源,需要手动更新sudo apt update

sudo apt-get update

??在这里插入图片描述
??更改树莓派手动更新:

sudo apt update

??出现无法更新的,点击y手动即可:
??在这里插入图片描述
??继续补刀查看:

sudo apt-get update
sudp apt-get upgrade

??在这里插入图片描述
??现在,update后的,tab都没有了
??在这里插入图片描述

??这里再补充一下:此时是没有了,后续继续编译mysql,然后又有了,如下图:
??在这里插入图片描述

??什么原因导致的不太清楚。(如果有建议这样安装,没必要编译源码,比较费时间还要解决各种错误)

步骤三:下载mysql源码

??下载:

wget http://dev.mysql.com/get/Downloads/MySQL-5.6/mysql-5.6.34.tar.gz

??在这里插入图片描述
??QQ群下载地址:1047134658(点击“文件”搜索“mysql”,群内与博文同步更新)

步骤四:复制解压

??大小不够进行了扩容,记住扩容的操作只能执行一次,执行超过一次(未重启)系统就会起不来。
??在这里插入图片描述
??解压:

mkdir -p ~/work/src

??拷贝进来,然后解压

cd ~/work/src
tar xvf mysql-5.6.34.tar.gz

??在这里插入图片描述

步骤五:cmake配置

??安装cmake:

sudo apt-get install cmake

??cmake配置:

cmake ./ -DCMAKE_INSTALL_PREFIX=/home/pi/mysql \
  -DMYSQL_DATADIR=/home/pi/mysql/data \
  -DSYSCONFDIR=/home/pi/mysql/ \
  -DWITH_MYISAM_STORAGE_ENGINE=1 \
  -DWITH_INNOBASE_STORAGE_ENGINE=1 \
  -DWITH_MEMORY_STORAGE_ENGINE=1 \
  -DWITH_READLINE=1 \
  -DMYSQL_UNIX_ADDR=/tmp/mysqld.sock \
  -DMYSQL_TCP_PORT=3306 \
  -DENABLED_LOCAL_INFILE=1 \
  -DWITH_PARTITION_STORAGE_ENGINE=1 \
  -DEXTRA_CHARSETS=all \
  -DDEFAULT_CHARSET=utf8 \
  -DDEFAULT_COLLATION=utf8_general_ci

??在这里插入图片描述
??出现错误:
??在这里插入图片描述
??需要先安装ncurses:

cd ~/work/src
wget https://invisible-mirror.net/archives/ncurses/ncurses-6.1.tar.gz
tar -xvf ncurses-6.1.tar.gz
cd ncurses-6.1/
./configure
make -j4
sudo make install

??在这里插入图片描述
??然后,继续配置:

cmake ./ -DCMAKE_INSTALL_PREFIX=/home/pi/mysql \
  -DMYSQL_DATADIR=/home/pi/mysql/data \
  -DSYSCONFDIR=/home/pi/mysql/ \
  -DWITH_MYISAM_STORAGE_ENGINE=1 \
  -DWITH_INNOBASE_STORAGE_ENGINE=1 \
  -DWITH_MEMORY_STORAGE_ENGINE=1 \
  -DWITH_READLINE=1 \
  -DMYSQL_UNIX_ADDR=/tmp/mysqld.sock \
  -DMYSQL_TCP_PORT=3306 \
  -DENABLED_LOCAL_INFILE=1 \
  -DWITH_PARTITION_STORAGE_ENGINE=1 \
  -DEXTRA_CHARSETS=all \
  -DDEFAULT_CHARSET=utf8 \
  -DDEFAULT_COLLATION=utf8_general_ci

??配置成功:
??在这里插入图片描述

步骤六:编译make

make -j4

??在这里插入图片描述
??出现错误:

error: ISO C++ forbids comparison between pointer and integer [-fpermissive]

??在这里插入图片描述
??直接修改源码:

vi sql/sql_acl.cc

??输入k,再输入3037即可定位到:
??在这里插入图片描述
??继续编译:

make -j4

??错误:查询时没有连接nurces,前面也确实安装了,但是这个错误是没有连接到ncurses库,需要自己添加下(各种方法都试了,最后直接强制指定):
??在这里插入图片描述
??建立软连接:

sudo ln -s libncurses.so.6 libncurses.so

??然后libncur*全部拷贝到/lib下

sudo cp -arf libncurses* ../

??然后cmake配置强制指定路径:

cmake ./ -DCMAKE_INSTALL_PREFIX=/home/pi/mysql \
  -DMYSQL_DATADIR=/home/pi/mysql/data \
  -DSYSCONFDIR=/home/pi/mysql/ \
  -DWITH_MYISAM_STORAGE_ENGINE=1 \
  -DWITH_INNOBASE_STORAGE_ENGINE=1 \
  -DWITH_MEMORY_STORAGE_ENGINE=1 \
  -DWITH_READLINE=1 \
  -DMYSQL_UNIX_ADDR=/tmp/mysqld.sock \
  -DMYSQL_TCP_PORT=3306 \
  -DENABLED_LOCAL_INFILE=1 \
  -DWITH_PARTITION_STORAGE_ENGINE=1 \
  -DEXTRA_CHARSETS=all \
  -DDEFAULT_CHARSET=utf8 \
  -DDEFAULT_COLLATION=utf8_general_ci \
  -DCURSES_LIBRARY=/lib/libncurses.so

??然后继续编译:

make

??在这里插入图片描述

步骤七:安装make install

sudo make install

??在这里插入图片描述
??安装完成:
??在这里插入图片描述

步骤八:测试mysql

??运行mysql:
??在这里插入图片描述
??错误:

Can't connect to local MySQL server through socket '/tmp/mysqld.sock' (2)

??查找:

find / -name mysql.sock

??在这里插入图片描述
??没有找到,然后找一下配置文件my.cnf

sudo find / -name my.cnf

??在这里插入图片描述
??是服务没有起来,需要配置一些服务,在这里就不追加了,有兴趣的可以继续。


上一篇:《树莓派开发笔记(十四):入手研华ADVANTECH工控树莓派UNO-220套件(三):使用研发自带系统测试rtc、gpio、232和485套件接口
下一篇:敬请期待…


若该文为原创文章,转载请注明原文出处
本文章博客地址:https://hpzwl.blog.csdn.net/article/details/125167513

  大数据 最新文章
实现Kafka至少消费一次
亚马逊云科技:还在苦于ETL?Zero ETL的时代
初探MapReduce
【SpringBoot框架篇】32.基于注解+redis实现
Elasticsearch:如何减少 Elasticsearch 集
Go redis操作
Redis面试题
专题五 Redis高并发场景
基于GBase8s和Calcite的多数据源查询
Redis——底层数据结构原理
上一篇文章      下一篇文章      查看所有文章
加:2022-06-08 19:06:49  更:2022-06-08 19:07:38 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年5日历 -2024/5/20 0:00:56-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码