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

Posted 长沙红胖子Qt

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了树莓派开发笔记(十五):树莓派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数据库的主要内容,如果未能解决你的问题,请参考以下文章

树莓派开发笔记(十七):树莓派4B+上Qt多用户连接操作Mysql数据库同步(单条数据悲观锁)

树莓派开发笔记(十六):树莓派4B+安装mariadb数据库(mysql开源分支)并测试基本操作

树莓派开发笔记(十七):树莓派4B+上Qt多用户连接操作Mysql数据库同步(单条数据悲观锁)

6.4-6.10博客精彩回顾

树莓派4B UbuntuMate20 安装 ROS Noetic 笔记

树莓派4B UbuntuMate20 安装 ROS Noetic 笔记