时间:2021-07-01 10:21:17 帮助过:6人阅读
Mysql编译安装准备工作:
(1) 为了避免发生端口冲突,程序冲突等现象,建议先查询Mysql软件的安装情况,确认没有使用过RPM方式安装的Mysql-server、Mysql软件包,否则建议卸载.
[root@1 ~]# rpm -q msyql-server mysql package msyql-server is not installed package mysql is not installed [root@1 ~]# 如有服务: [root@1 ~]# rpm -e mysql-server mysql --nodeps
(2) 安装依赖包ncurses-devel
[root@1 ~]# yum -y install ncurses-devel Complete!
(3) 安装配置工具cmake
[root@RHEL6-Server1 ~]# tar xf cmake-2.8.12.tar.gz -C /usr/src/ [root@RHEL6-Server1 ~]# cd /usr/src/cmake-2.8.12/ [root@RHEL6-Server1 cmake-2.8.12]# ./configure && gmake && gmake install
源码编译及安装:
(1)创建运行用户
为了加强数据库服务的权限控制,建议使用专门的运行级用户,如Mysql,此用户不需要直接登陆到系统,可以不创建宿主文件夹.
[root@1 ~]# groupadd mysql [root@1 ~]# useradd -M -s /sbin/nologin -g mysql mysql [root@1 ~]#
(2)解包
将下载的MySQL源码包解压,释放到/usr/src/目录下,并切换到展开后的源码目录
[root@1 ~]# tar zxf mysql-5.7.20.tar.gz -C /usr/src/ [root@1 ~]# cd /usr/src/mysql-5.7.20.tar.gz
(3) 配置
在网站平台中,可能会用到多种字符集的网页,相应的数据库系统也应该支持不同字符集编码,可以在配置过程中将默认使用的字符串设置为utf-8,并添加其他字符集的支持.
[root@RHEL6-Server1mysql-5.7.2-m12]#cmake -DCMAKE_INSTALL_PREFIX=/usr/local/mysql -DDEFAULT_CHARSET=utf8 -DDEFAULT_COLLATION=utf8_general_ci -DWITH_EXTRA_CHARSETS=all -DSYSCONFDIR=/etc && make && make install
注释:
-DCMAKE_INSTALL_PREFIX=/usr/local/mysql //将指定的mysql数据库程序安装到/usr/local/mysql下
-DDEFAULT_CHARSET=utf8 //默认字符集为 utf8
-DDEFAULT_COLLATION=utf8_general_ci //默认的字符集校对规则
-DWITH_EXTRA_CHARSETS=all //安装所有字符集
-DSYSCONFDIR=/etc //配置文件存放目录,指定初始化参数目录文件
安装后的其他调整:
(1) 对数据库目录进行权限设置:
[root@vmc1 etc]# chown -R mysql:mysql /usr/local/mysql/
(2) 建立配置文件:
在mysql源码目录中的support-files文件夹下,提供了适合不同负载均衡数据库的样本配置文件,如果不确定数据库系统的的应用规模,,一般选择my-default.cnf文件即可,该文件能满足大多数的中等应用需求,根据以下参考内容建立mysql系统的/etc/my.cnf配置文件。
[root@vmc1 etc]# rm -rf /etc/my.cnf //如果原来的etc文件下有my.cnf 文件可以删除。
[root@vmc1 mysql-5.7.2-m12]# cp support-files/my-default.cnf /etc/my.cnf
(3) 初始化数据库:
为了能够正常使用mysql数据库系统,应用运行用户mysql的身份执行初始化脚本mysql-install_db 指定数据存放目录
/usr/local/mysql/scripts/mysql_install_db --basedir=/usr/local/mysql/ --datadir=/usr/local/mysql/data --user=mysql
--basedir=/usr/local/mysql/ //指定安装目录(产品目录)
--datadir=/usr/local/mysql/data //指定数据目录
--user=mysql //指定用户身份
(4)设置变量环境:
为了方便在任何目录下使用mysql命令需要在etc下profile设置变量:
[root@vmc1 mysql-5.7.2-m12]#echo "PATH=$PATH:/usr/local/mysql/bin" >> /etc/profile [root@vmc1 mysql-5.7.2-m12]#. /etc/profile = source /etc/profile
添加系统服务:
若希望添加mysqld系统服务,以便于通过chkconfing进行管理,可以直接使用源码包中提供的服务脚本,找到support-files文件夹下的mysql-server脚本,将其复制到etc下rc.d下init.d 并且改名为mysqld 然后在设置权限,通过执行chkconfing命令将其添加到mysqd系统服务:
[root@vmc1 mysql-5.7.2-m12]#cp support-files/mysql.server /etc/init.d/mysqld [root@vmc1 mysql-5.7.2-m12]#chmod +x /etc/init.d/mysqld [root@vmc1 mysql-5.7.2-m12]#chkconfig --add mysqld [root@vmc1 mysql-5.7.2-m12]#chkconfig --list mysqld mysqld 0:关闭 1:关闭 2:启用 3:启用 4:启用 5:启用 6:关闭
这样以后可以使用service工具或者直接执行/etc/init.d/mysqld 脚本来控制mysql
[root@1 scripts]# /etc/init.d/mysqld status MySQL running (12025) [ OK ] [root@1 scripts]# [root@1 scripts]# netstat -anpt | grep mysqld tcp6 0 0 :::3306 :::* LISTEN 12025/mysqld [root@1 scripts]#
Mysq服务默认通过tcp3306端口提供服务,通过编辑etc下的my.cnf 配置文件中【mysqld】配置段的port - 3306 行,可以更改监听端口.
Mysql数据库系统也是一个典型的C/S(客户端/服务器),架构的应用,要访问mysql数据库需要使用专门的客户端软件,在liux
my.cnf 配置文件相关介绍,在mysql解压路径support-files/下提供的模版
my-huge.cnf 巨大数据量
my-innodb-heavy-4G.cnf innodb引擎
my-large.cnf 大数据量
my-medium.cnf 测试使用
my-small.cnf 小数据量
MySQL 数据库存储引擎:
myisam
innodb
多个配置文件时的应用顺序,后一个覆盖前一个配置文件
/etc/my.cnf --> /etc/mysql/my.cnf --> $BASEDIR/my.cnf --> ~/.my.cnf
MySQL 是C/S结构,连接时需要客户端工具,Linux下mysql(如果是通过rpm格式安装软件需要安装mysql 软件包)
连接并登录到MySQL操作环境
mysql -u 指定用户名
-p 指定密码
-h 指定主机
-P 指定端口
netstat -anpt |grep mysqld
tcp 3306 端口
[root@RHEL6-Server1 ~]# mysql -u root 默认root为Mysql用户,并为空密码
设置数据库用户的密码
mysqladmin -u root password ‘123456‘
安装MySQL
标签:网站平台 pass 命令 脚本 登录 服务脚本 stat pack 依赖