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

[经验分享] MySQL 源代码安装mysql-5.5.28

[复制链接]

尚未签到

发表于 2018-9-30 10:33:07 | 显示全部楼层 |阅读模式
  全新以最小化包安装了64位的CentOS6.3系统,作为本地的Web服务器使用,现记录全过程
  第六步,安装mysql5.5数据库v5.5.28
  mysql从5.5版本开始,不再使用./configure编译,而是使用cmake编译器,具体的cmake编译参数可以参考mysql官网文档(※ 非常重要)
  http://dev.mysql.com/doc/refman/5.5/en/source-configuration-options.html
  mysql-5.5.28.tar.gz源码包下载地址:
  http://cdn.mysql.com/Downloads/MySQL-5.5/mysql-5.5.28.tar.gz
  我的mysql目录配置如下:
  安装路径:/usr/local/mysql
  数据库路径:/data/mysql
  源码包存放位置:/usr/software
  准备工作:安装基本依赖包,先用yum安装cmake、automake 、autoconf ,另MySQL 5.5.x需要最少安装的包有:bison,gcc、gcc-c++、ncurses-devel
  [root@localhost ~]# yum install cmake make -y
  [root@localhost ~]# yum install gcc gcc-c++ autoconf bison automake zlib* fiex* libxml* ncurses-devel libmcrypt* libtool-ltdl-devel* -y
  [root@localhost ~]# cp /root/mysql-5.5.28.tar.gz /usr/software/
  [root@localhost ~]# cd /usr/software
  开始编译安装
  [root@localhost ~]# tar -zxvf mysql-5.5.28.tar.gz
  [root@localhost ~]# cd mysql-5.5.28
  [root@localhost ~]# cmake -DCMAKE_INSTALL_PREFIX=/usr/local/mysql-5.5.28\
  -DMYSQL_UNIX_ADDR=/usr/local/mysql-5.5.28/mysql.sock \
  -DDEFAULT_CHARSET=utf8 \
  -DDEFAULT_COLLATION=utf8_general_ci \
  -DWITH_EXTRA_CHARSETS:STRING=utf8,gbk \
  -DWITH_INNOBASE_STORAGE_ENGINE=1 \
  -DWITH_READLINE=1 \
  -DENABLED_LOCAL_INFILE=1 \
  -DMYSQL_DATADIR=/usr/local/mysql-5.5.28\
  -DMYSQL_USER=mysql \
  -DMYSQL_TCP_PORT=3306
  cmake -DCMAKE_INSTALL_PREFIX=/usr/local/mysql-5.5.28 -DMYSQL_UNIX_ADDR=/usr/local/mysql-5.5.28/mysql.sock -DDEFAULT_CHARSET=utf8 -DDEFAULT_COLLATION=utf8_general_ci  -DWITH_EXTRA_CHARSETS:STRING=utf8,gbk -DWITH_INNOBASE_STORAGE_ENGINE=1 -DWITH_READLINE=1 -DENABLED_LOCAL_INFILE=1 -DMYSQL_DATADIR=/mnt/sdb1/mysqldata -DMYSQL_USER=mysql -DMYSQL_TCP_PORT=3306
  [root@localhost ~]# make && make install
  mysql官网英文文档简单翻译说明一下
  The MyISAM, MERGE, MEMORY, and CSV engines are mandatory (always compiled into the server) and need not be installed explicitly.(说明:mysql默认支持的数据库引擎有MyISAM, MERGE, MEMORY, CSV,无需在编译时再声明)
  所以上面的编译条件省掉了如下两行
  -DWITH_MYISAM_STORAGE_ENGINE=1 \
  -DWITH_MEMORY_STORAGE_ENGINE=1 \
  但INNODB一定要声明式安装,所以多了这一行
  -DWITH_INNOBASE_STORAGE_ENGINE=1 \
  查看mysql.mysql的用户及组是否存在
  不OK就执行以下两行命令(否则跳过这一步)
  [root@localhost ~]# groupadd mysql                                          #添加mysql用户组
  [root@localhost ~]# useradd mysql -g mysql -s /sbin/nologin        # 添加mysql用户
  以下带红色字体的命令非常非常,必须要执行
  [root@localhost ~]# cd /usr/local/mysql
  [root@localhost ~]# chown mysql.mysql -R .                               #将mysql目录赋予mysql用户的执行权限
  [root@localhost ~]# chown mysql.mysql -R /data/mysql
  [root@localhost ~]# cp support-files/my-medium.cnf /etc/my.cnf   #mysql配置文件
  [root@localhost ~]# chmod 755 scripts/mysql_install_db               #赋予mysql_install_db执行权限
  以下命令为mysql 启动及自启动配置
  [root@localhost ~]# ./scripts/mysql_install_db  --user=mysql  --basedir=/usr/local/mysql --datadir=/data/mysql/
  ===========================================================================
  初始化数据库:(修改数据库默认的存储路径)
  [root@localhost ~]#./scripts/mysql_install_db --basedir=/usr/local/mysql-5.5.28/ --datadir=/mnt/sdb1/mysqldata/ --plugin-dir=/usr/local/mysql-5.5.28/lib/plugin/ --user=mysql --log-error=/usr/local/mysql-5.5.28/data/ --pid-file=/usr/local/mysql-5.5.28/data/ --socket=/usr/local/mysql-5.5.28/mysql.sock  --port=3306
  查看生效的配置文件路径:
  [root@node206 mysql-5.5.28]# ps -ef | grep mysqld
  root     12104     1  0 00:50 pts/0    00:00:00 /bin/sh /usr/local/mysql-5.5.28/bin/mysqld_safe --datadir=/mnt/sdb1/mysqldata --pid-file=/usr/local/mysql-5.5.28/node206.pid
  mysql    12356 12104  1 00:50 pts/0    00:00:00 /usr/local/mysql-5.5.28/bin/mysqld --basedir=/usr/local/mysql-5.5.28 --datadir=/mnt/sdb1/mysqldata --plugin-dir=/usr/local/mysql-5.5.28/lib/plugin --user=mysql --log-error=/mnt/sdb1/mysqldata/node206.err --pid-file=/usr/local/mysql-5.5.28/node206.pid --socket=/usr/local/mysql-5.5.28/mysql.sock --port=3306
  root     12395  2386  0 00:51 pts/0    00:00:00 grep mysqld
  修改配置文件:/etc/init.d/mysqld
  修改pid运行时存放的路径
  将:datadir修改为basedir
  if test -z "$mysqld_pid_file_path"                  //在/etc/init.d/mysqld 第261行
  then
  mysqld_pid_file_path=$basedir/`hostname`.pid
  else
  case "$mysqld_pid_file_path" in
  /* ) ;;
  * )  mysqld_pid_file_path="$basedir/$mysqld_pid_file_path" ;;
  esac
  fi
  修改数据库存放路径:
  # Set some defaults
  mysqld_pid_file_path=
  if test -z "$basedir"
  then
  basedir=/usr/local/mysql-5.5.28
  bindir=/usr/local/mysql-5.5.28/bin
  if test -z "$datadir"
  then
  datadir=/mnt/sdd/data                        //在/etc/init.d/mysqld 第70行
  fi
  sbindir=/usr/local/mysql-5.5.28/bin
  libexecdir=/usr/local/mysql-5.5.28/bin
  else
  bindir="$basedir/bin"
  if test -z "$datadir"
  then
  datadir="$basedir/data"
  fi
  sbindir="$basedir/sbin"
  libexecdir="$basedir/libexec"
  fi
  =============================================================================
  启动数据库:(生成pid文件,err文件,生成数据库路径)
  [root@localhost ~]# /usr/local/mysql/bin/mysqld_safe &
  将mysqld_safe放到/etc/rc.d/rc.local 跟系统一起自动启动
  /usr/local/mysql-5.5.28/bin/mysqld_safe --user=mysql &
  配置开机自启动:
  [root@localhost ~]# cp support-files/mysql.server /etc/init.d/mysqld
  [root@localhost ~]# chmod 755 /etc/init.d/mysqld
  查看mysqld的启动参数:
  [root@localhost ~]#ps -aux | grep mysqld
  查看mysqld服务是否设置为开机启动
  [root@localhost ~]# chkconfig --list|grep mysqld
  设置为开机启动
  [root@localhost ~]# chkconfig mysqld on
  启动mysql数据库,会输出一系列有用的信息,告诉你接下去如何初始化mysql
  [root@centos mysql]# service mysqld start
  初始化 MySQL 数据库: Installing MySQL system tables...
  OK
  Filling help tables...
  OK
  To start mysqld at boot time you have to copy
  support-files/mysql.server to the right place for your system
  PLEASE REMEMBER TO SET A PASSWORD FOR THE MySQL root USER !
  To do so, start the server, then issue the following commands:
  /usr/bin/mysqladmin -u root password 'new-password'
  /usr/bin/mysqladmin -u root -h centos.huoba password 'new-password'
  Alternatively you can run:
  /usr/bin/mysql_secure_installation
  which will also give you the option of removing the test
  databases and anonymous user created by default.  This is
  strongly recommended for production servers.
  See the manual for more instructions.
  You can start the MySQL daemon with:
  cd /usr ; /usr/bin/mysqld_safe &
  You can test the MySQL daemon with mysql-test-run.pl
  cd /usr/mysql-test ; perl mysql-test-run.pl
  Please report any problems with the /usr/bin/mysqlbug script!
  按照上述英文,我们来初始化管理员root的密码
  [root@localhost ~]# /usr/bin/mysqladmin -u root password 'yourpassword'  //修改root密码
  众所周知,mysql有两种帐号类型,即localhost和%,前者限本机连接mysql,后者可用于其它机器远程连接mysql
  最后,处理帐号登录问题,让root帐号密码可以本地和远程连接使用
  [root@localhost ~]# mysql -u root -p                                       #敲入该命令后,屏幕会提示输入密码,输入上一步设置的yourpassword
  删除root密码为空的记录
  mysql> use mysql;
  mysql> delete from user where password='';
  mysql> flush privileges;
  配置mysql允许root远程登录                                   #登录
  mysql> grant all privileges on *.* to root@'%' identified by "root";
  mysql> flush privileges;
  mysql> select User,Password,Host from user;
  日志文件存放位置(一般在数据库存放的位置):
  #/usr/local/mysql/data
  文件名为:
  hostname.err


运维网声明 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-606629-1-1.html 上篇帖子: Mysql(五)-数据恢复 下篇帖子: MySQL数据库------索引
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

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

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

扫描微信二维码查看详情

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


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


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


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



合作伙伴: 青云cloud

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