知识养成了思想,思想同时又在融化知识。这篇文章主要讲述树莓派开发笔记(十五):树莓派4B+从源码编译安装mysql数据库相关的知识,希望能为你提供帮助。
前言
树莓派使用数据库时,优先选择sqlite数据库,但是sqlite是文件数据库同时仅针对于单用户的情况,考虑到多用户的情况,在树莓派上部署安装mysql服务,通过读写锁事务等使用,可以实现多进程可以操作同一个数据库的同一个表的读写并行操作。
<
br>
树莓派安装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
文章图片
步骤四:复制解压 大小不够进行了扩容,记住扩容的操作只能执行一次,执行超过一次(未重启)系统就会起不来。
文章图片
解压:
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:
文章图片
错误:
Cant connect to local MySQL server through socket /tmp/mysqld.sock (2)
查找:
find / -name mysql.sock
文章图片
没有找到,然后找一下配置文件my.cnf
sudo find / -name my.cnf
【树莓派开发笔记(十五)(树莓派4B+从源码编译安装mysql数据库)】
文章图片
是服务没有起来,需要配置一些服务,在这里就不追加了,有兴趣的可以继续。
推荐阅读
- windows系统-PKI证书服务器
- Flannel 学习指南
- 软件设计文档最容易忽略内容看这里!
- 全志D1-H Dock ProYoC RTOS 实战(FOTA系统升级)
- (Message组件)
- scrapy爬取图片站
- MA8601 pin√pin替代汤铭FE1.1s无须更改电路板|完美替代FE1.1s方案
- Docker容器实战九(容器生命周期管理)
- 4G智能安全帽(记录仪)应用分析