Bootstrap

MySQL

MySQL

一.基于CentOS7的MySQL离线安装

  • 上传压缩包到/usr/local目录下
 rpm -qa | grep mariadb 查看自带数据库
 rpm -e --nodeps mariadb-libs-5.5.68-1.el7.x86_64   卸载自带数据库
打开数据库:service mysql start
[root@server2 /]# cd /usr/local/
[root@server2 local]# ls
bin  etc  games  include  lib  lib64  libexec  sbin  share  src
[root@server2 local]# ls
bin  etc  games  include  lib  lib64  libexec  mysql-5.7.31-el7-x86_64.tar.gz  sbin  share  src
  • 解压文件
[root@server2 local]# tar -zxvf mysql-5.7.43-el7-x86_64.tar.gz 
  • mv修改文件名
[root@server2 local]# ls
bin  etc  games  include  lib  lib64  libexec  mysql-5.7.31-el7-x86_64  mysql-5.7.31-el7-x86_64.tar.gz  sbin  share  src
[root@server2 local]# mv mysql-5.7.31-el7-x86_64 mysql 修改文件名为mysql
[root@server2 local]# ls
bin  etc  games  include  lib  lib64  libexec  mysql  mysql-5.7.31-el7-x86_64.tar.gz  sbin  share  src
[root@server2 local]# rm -rf mysql-5.7.31-el7-x86_64.tar.gz 删除压缩包
  • 创建data目录
[root@server2 local]# mkdir -p mysql/data
  • 创建mysql用户组和用户
[root@server2 local]# groupadd mysql
[root@server2 local]# useradd mysql -g mysql
  • 修改mysql文件所属用户和用户组
[root@server2 local]#chmod -R 777/usr/local/mysql/data
 chmod 修改权限
-R  处理指定目录以及其子目录下的所有文件
  • 编辑my.cnf文件
[mysqld]
bind-address=0.0.0.0
port=3306
user=mysql
basedir=/usr/local/mysql
datadir=/usr/local/mysql/data
socket=/tmp/mysql.sock
log-error=/usr/local/mysql/data/mysql.err
pid-file=/usr/local/mysql/data/mysql.pid
#character config
character_set_server=utf8mb4
symbolic-links=0
  • 初始化mysql
cd /usr/local/mysql/bin
执行命令
./mysqld --initialize --user=mysql --datadir=/usr/local/mysql/data/ --basedir=/usr/local/mysql/
  • 添加软连接 并重启mysql
ln -s /usr/local/mysql/support-files/mysql.server /etc/init.d/mysql
ln -s /usr/local/mysql/bin/mysql /usr/bin/mysql
service mysql start

登录mysql修改密码和访问权限

进入mysql  bin目录下面
mysql -u root -p

修改密码

set password=password('123456');
flush privileges;

修改访问权限

use mysql;
update user set Host='%' where User='root';
flush privileges;

设置MySQL开机自启动

systemctl enable mysql.service         启用 MySQL 服务的自启动功能
systemctl daemon-reload                重新加载 systemd 系统服务管理器
 systemctl start mysql.service         启动 MySQL 服务
  • 创建用户
  • username:要创建的用户名;
    host:代表地址;任何地址可以使用%
    IDENTIFIED BY ‘password’:设置密码,如果不写则为空密码
CREATE USER 'username'@'host' [IDENTIFIED BY 'password'];
create user 'nb'@'%' identified BY '123456';
  • privileges: 用户的操作权限,如SELECT,INSERT,UPDATE等,如果要授予所有的权限则使用ALL
  • databasename: 数据库名,如果*代表所有数据库
  • tablename: 表名,如果*代表所有数据表
  • host: 指定该用户在哪个主机上可以登陆,如果是本地用户可用localhost,如果想让该用户可以从任意远程主机登陆,可以使用通配符号%
GRANT privileges ON databasename.tablename TO 'username'@'host' 
grant all ON *.* TO 'nb'@'%'; 
刷新权限:
flush privileges;

符号%

GRANT privileges ON databasename.tablename TO 'username'@'host' 
grant all ON *.* TO 'nb'@'%'; 
刷新权限:
flush privileges;
;