设为首页 收藏本站
查看: 1189|回复: 0

[经验分享] mysql5.7 cmake源码编译安装

[复制链接]

尚未签到

发表于 2018-10-6 10:40:45 | 显示全部楼层 |阅读模式
  mysql5.7 cmake源码编译安装,
  -----该文章的知识点是一个大牛总结的,我这里只是加工了一下,非原创文章。
  搜狐开源镜像站:http://mirrors.sohu.com/
  网易开源镜像站:http://mirrors.163.com/
  开源中国:http://mirrors.oschina.net/
  首都在线科技股份有限公司:http://mirrors.yun-idc.com/
  阿里云开源镜像:http://mirrors.aliyun.com/
  LUPA:http://mirror.lupaworld.com/
  常州贝特康姆软件技术有限公司(原cn99):http://centos.bitcomm.cn/
  一、安装MySQL
  1、安装cmake
  cd /usr/local/src
  tar zxvf cmake-3.7.2.tar.gz
  cd cmake-3.7.2
  ./configure
  make
  make install
  2、安装MySQL
  cd /usr/local/src
  mkdir -p /usr/local/boost
  cp boost_1_59_0.tar.gz /usr/local/boost
  #cmake的时候去这个路径解压该boost_1_59_0.tar.gz包(为什么这么做,是因为曾经这里遇到过一个问题:
  在网上看到有文章写到,源码安装mysql时候,需要先安装boost库,于是执行了下面的命令
  一、安装boost库
  1 tar xvf boost_1_59_0
  2 cd boost_1_59_0
  3 ./bootstrap.sh --with-libraries=system,filesystem,log,thread --with-toolset=gcc
  4 ./b2 toolset=gcc cxxflags="-std=c++11"
  5 ./b2 install --prefix=/usr/local/boost
  二、cmake mysql5.7
  cmake -DCMAKE_INSTALL_PREFIX=/usr/local/mysql -DMYSQL_DATADIR=/usr/local/mysql/data -DSYSCONFDIR=/etc -DWITH_MYISAM_STORAGE_ENGINE=1 -DWITH_INNOBASE_STORAGE_ENGINE=1 -DWITH_MEMORY_STORAGE_ENGINE=1 -DWITH_READLINE=1 -DMYSQL_UNIX_ADDR=/var/lib/mysql/mysql.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 -DDOWNLOAD_BOOST=1 -DWITH_BOOST=/usr/local//boost/
  报错:
  Call Stack (most recent call first):
  cmake/boost.cmake:167 (COULD_NOT_FIND_BOOST)
  CMakeLists.txt:451 (INCLUDE)
  参数:DDOWNLOAD_BOOST=1 -DWITH_BOOST=/usr/local//boost/  # 这2个参数意思是cmake的时候去/usr/local//boost找 boost,如果没有就去下载,但是之前通过安装boost库,无论如何cmake都找不到boost文件,后来问了几个大牛,说上面不用安装boost库,直接把boost库的tar.gz包拷贝到/usr/local//boost/下即可;我个人猜测可能跟编译php的时候一个道理,例如,我们编译php扩展库-with-gd with-png-dir=/usr/local/libpng,编译gd的时候,gd也要去找libpng,libpng有系统lib库的默认位置,这里php编译去/usr/local/libpng了,gd却去系统默认位置找了,导致gd编译失败,从而导致这里php编译png成功了,php编译gd的时候失败,因为gd去默认位置找了,----这里不是本章重点,可以忽略,大概解决办法就是去makefile文件里找到对应的变量修改成对应的路径,再重新编译配置,未测试过,仅做参考。
  )
  啰嗦完了,下面继续正常安装流程:
  groupadd mysql #添加mysql组
  useradd -g mysql mysql -s /bin/false #创建用户mysql并加入到mysql组,不允许mysql用户直接登录系统
  mkdir -p /data/mysql #创建MySQL数据库存放目录
  chown -R mysql:mysql /data/mysql #设置MySQL数据库存放目录权限
  mkdir -p /usr/local/mysql #创建MySQL安装目录
  cd /usr/local/src #进入软件包存放目录
  tar zxvf mysql-5.7.16.tar.gz #解压
  cd mysql-5.7.16 #进入目录
  cmake . -DCMAKE_INSTALL_PREFIX=/usr/local/mysql -DMYSQL_DATADIR=/data/mysql -DWITH_INNOBASE_STORAGE_ENGINE=1 -DDEFAULT_CHARSET=utf8 -DDEFAULT_COLLATION=utf8_general_ci -DWITH_EMBEDDED_SERVER=OFF -DWITH_BOOST=/usr/local/boost
  注意:可以使用-DDOWNLOAD_BOOST=1 -DWITH_BOOST=/usr/local/boost参数在线安装boost软件包,需要服务器联网,容易下载失败。
  cmake -DCMAKE_INSTALL_PREFIX=/usr/local/mysql -DMYSQL_DATADIR=/usr/local/mysql/data -DSYSCONFDIR=/etc -DWITH_MYISAM_STORAGE_ENGINE=1 -DWITH_INNOBASE_STORAGE_ENGINE=1 -DWITH_MEMORY_STORAGE_ENGINE=1 -DWITH_READLINE=1 -DMYSQL_UNIX_ADDR=/var/lib/mysql/mysql.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 -DDOWNLOAD_BOOST=1 -DWITH_BOOST=/usr/local//boost/
  make #编译
  make install #安装
编译出错, 重新编译前要删除编译失败的文件,重新编译时,需要清除旧的对象文件和缓存信息。
  make clean
  rm -f CMakeCache.txt
  rm -rf /etc/my.cnf #删除系统默认的配置文件(如果默认没有就不用删除)
  cd /usr/local/mysql #进入MySQL安装目录
  ./bin/mysqld --user=mysql --initialize --basedir=/usr/local/mysql --datadir=/data/mysql #生成mysql系统数据库
  --initialize表示默认生成密码, --initialize-insecure 表示不生成密码, 密码为空。
  看到这一行[Note] A temporary password is generated for root@localhost: i>X18*=Rav=7
  cp /usr/local/mysql/support-files/my-default.cnf /usr/local/mysql/my.cnf
  ln -s /usr/local/mysql/my.cnf /etc/my.cnf #添加到/etc目录的软连接
  cp /usr/local/mysql/support-files/mysql.server /etc/rc.d/init.d/mysqld #把Mysql加入系统启动
  chmod 755 /etc/init.d/mysqld #增加执行权限
  chkconfig mysqld on #加入开机启动
  vi /etc/rc.d/init.d/mysqld #编辑
  basedir=/usr/local/mysql #MySQL程序安装路径
  datadir=/data/mysql #MySQl数据库存放目录
  :wq! #保存退出
  service mysqld start #启动
  vi /etc/profile #把mysql服务加入系统环境变量:在最后添加下面这一行
  export PATH=$PATH:/usr/local/mysql/bin
  :wq! #保存退出
  source /etc/profile #使配置立刻生效
下面这两行把myslq的库文件链接到系统默认的位置,这样你在编译类似PHP等软件时可以不用指定mysql的库文件地址。
  ln -s /usr/local/mysql/lib/mysql /usr/lib/mysql
  ln -s /usr/local/mysql/include/mysql /usr/include/mysql
  mkdir /var/lib/mysql #创建目录
  ln -s /tmp/mysql.sock /var/lib/mysql/mysql.sock #添加软链接
  mysql_secure_installation #修改Mysql密码,输入之前生成的密CSJlm3DyTG.d回车,根据提示操作。
  Press y|Y for Yes, any other key for No: y #是否安装密码安全插件?选择y
  There are three levels of password validation policy: #有以下几种密码强度选择
  LOW Length >= 8
  MEDIUM Length >= 8, numeric, mixed case, and special characters
  STRONG Length >= 8, numeric, mixed case, special characters and dictionary file
  Please enter 0 = LOW, 1 = MEDIUM and 2 = STRONG: 0 #选择0,只要8位数字即可,选1要有大写,小写,特殊字符等
  UNINSTALL PLUGIN validate_password ; #卸载密码强度插件
  mysqladmin -uroot -p password 123456 #修改密码
  show variables like "%pass%";
  set global validate_password_length=4; #修改密码规则
  set global validate_password_policy=0;
  set password = password('1234');
  '''
  ps -ef |grep mysql
  /bin/sh /usr/local/mysql/bin/mysqld_safe --datadir=/data/mysql --pid-file=/data/mysql/iZ230hvszdwZ.pid
  /usr/local/mysql/bin/mysqld --basedir=/usr/local/mysql --datadir=/data/mysql --plugin-dir=/usr/local/mysql/lib/plugin --user=mysql --log-error=/data/mysql/iZ230hvszdwZ.err --pid-file=/data/mysql/iZ230hvszdwZ.pid
root密码忘记了,数据库进不去了,怎么改密码呢:
  /etc/init.d/mysqld stop
  用这种方式启动mysql
  mysqld_safe --skip-grant-tables --skip-networking &
  mysql -uroot -p  #进入mysql
  执行该命令修改密码
  update mysql.user set authentication_string=password('123456') where user='root' and Host = 'localhost';
  退出,kill -9 mysql的进程
  正常启动mysql:
  /etc/init.d/mysqld start


运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-613590-1-1.html 上篇帖子: Mysql中事物及隔离级别 下篇帖子: mysql联表查询脚本
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表