检查是否安装了mysql
rpm -qa | grep mysql
如有,类似
mysql-libs-5.1.52-1.el6_0.1.x86_64
卸载之
rpm -e --nodeps mysql-libs-5.1.52.x86_64
检查否存在 mariadb 数据库,如有,卸载之,卸载同上
rpm -qa | grep mariadb
查看linux系统是64位还是32位
getconf LONG_BIT
到mysql官网下载安装包(64位)
mysql-5.7.25-linux-glibc2.12-x86_64.tar.gz
上传安装包至/usr/local,解压安装包
cd /usr/local
tar -zvxf mysql-5.7.25-linux-glibc2.12-x86_64.tar.gz
重命名
mv mysql-5.7.25-linux-glibc2.12-x86_64.tar.gz mysql-5.7.25
创建data目录
cd mysql-5.7.25
mkdir data
检查mysql组和用户是否存在,如无创建
cat /etc/group | grep mysql
#类似
mysql:x:490:
cat /etc/passwd | grep mysql
#类似
mysql:x:496:490::/home/mysql:/bin/bash
以上为存在的情况,如无,执行添加命令:
groupadd mysql
useradd -r -g mysql mysql
#useradd -r参数表示mysql用户是系统用户,不可用于登录系统
将/usr/local/mysql-5.7.25的所有者及所属组改为mysql
chown -R mysql.mysql /usr/local/mysql-5.7.25
在/usr/local/mysql-5.7.25/support-files目录下创建my_default.cnf
# For advice on how to change settings please see
# http://dev.mysql.com/doc/refman/5.7/en/server-configuration-defaults.html
# *** DO NOT EDIT THIS FILE. It's a template which will be copied to the
# *** default location during install, and will be replaced if you
# *** upgrade to a newer version of MySQL.
[mysqld]
sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES
basedir = /usr/local/mysql-5.7.25
datadir = /usr/local/mysql-5.7.25/data
port = 3306
socket = /tmp/mysql.sock
character-set-server=utf8
log-error = /usr/local/mysql-5.7.25/data/mysqld.log
pid-file = /usr/local/mysql-5.7.25/data/mysqld.pid
拷贝
cp ./support-files/my-default.cnf /etc/my.cnf
初始化 mysqld
cd /usr/local/mysql-5.7.25/bin
./mysqld --initialize --user=mysql --basedir=/usr/local/mysql-5.7.25/ --datadir=/usr/local/mysql-5.7.25/data/
初始化完成之后,查看日志
/usr/local/mysql-5.7.25/data/mysqld.log
临时密码
[Note] A temporary password is generated for root@localhost: i8r#tnAuaanT
把启动脚本放到开机初始化目录
cp support-files/mysql.server /etc/init.d/mysql
启动mysql服务
service mysql start
查看mysql进程
ps -ef | grep mysql
登录mysql,密码为初始密码
cd /usr/local/mysql-5.7.25/bin
./mysql -u root -p
修改密码
mysql> set password=password('root');
mysql> grant all privileges on *.* to root@'%' identified by 'root';
mysql> flush privileges;
添加远程访问权限
mysql> use mysql;
mysql> update user set host='%' where user = 'root';
mysql> flush privileges;
重启mysql生效
mysql> service mysql stop
mysql> service mysql start
或
mysql> service mysql restart
---------------------
2.3. 系统启动时自动启动mysql服务
加入到系统服务:
chkconfig --add mysql
自动启
chkconfig mysql on
查询列表:
chkconfig
说明:都没关闭(off)时是没有自动启动。
2.4. 开启远程访问
登录:
mysql -uroot –p123456
设置远程访问(使用root密码):
grant:赋予
privileges:权限,规则
grant all privileges on *.* to 'root' @'%' identified by '123456';
flush privileges;
防火墙打开3306端口
/sbin/iptables -I INPUT -p tcp --dport 3306 -j ACCEPT
将打开的端口的访问规则保存在文件中
/etc/rc.d/init.d/iptables save
查看机器开放的端口号
/etc/init.d/iptables status
有什么细节问题,可以加我微信。