文章目录
1、检查是否装有MySQL
rpm -qa | grep mysql
2、下载mysql的repo源
wget http://repo.mysql.com/mysql-community-release-el7-5.noarch.rpm
3、安装上面下载的repo包
rpm -ivh mysql-community-release-el7-5.noarch.rpm
4、安装mysql
yum install mysql-server
centos下安装的mysql,root用户初始密码由系统默认生成,需要登录一次以后才可以查看。
5、无密码登录
mysql -u root
(1)登录时可能出现下面的错误
ERROR 2002 (HY000): Can’t connect to local MySQL server through socket ‘/var/lib/mysql/mysql.sock’
(2)错误原因/var/lib/mysql的访问权限问题,如下图所示,现在的权限是mysql,修改为root
(3)解决办法:修改权限
chown root /var/lib/mysql/
6、重启
service mysqld restart
7、查看初始密码
cat 'temporary password' /var/log/mysqld.log
下图中的就是我的初始密码
8、有密码登陆mysql
mysql -u root -p
我登陆后想创建一个用户时,mysql提示我必须修改root的密码,如下所示。
mysql> create user 'mysql'@'localhost' identified by '123456';
ERROR 1820 (HY000): You must reset your password using ALTER USER statement before executing this statement.
9、修改root密码
mysql> ALTER USER 'root'@'localhost' IDENTIFIED BY 'passwd';
10、创建新用户
mysql> create user 'mysql'@'%' identified by 'passwd';
11、給新用户授予mysql相关权限
# 允许远程访问权限
mysql> create user 'mysql'@'%' identified by 'passwd';
# 分配权限
mysql> grant all privileges on testdb.* to username@'%' identified by 'userpwd' with grant option;
# 参数解释
第一处all privileges:表明给用户授予哪些权限,all/all privileges表示所有权限,我们也可以指定部分权限如create、update等等。
第二处testdb:表明授权用户对哪个数据库拥有权限,*表示对所有数据库都有权限。
第三处’%’:指示该用户可以在哪些主机上登陆,’%’表示所有主机都可登录。
第四处with grant option:加上这个参数表明用户(root用户不需要加)可以把自己已有的权限赋给第三方,不加的话就不可以。比如我们通过root用户给test用户分配权限,test用户想再给其他用户赋予权限就要加with grant option。
12、刷新授权
flush privileges;
13、服务器重启
service mysqld restart
n。
#### 12、刷新授权
```shell
flush privileges;
13、服务器重启
service mysqld restart
如果想用navicat登陆mysql的话需要去服务器去打开3306端口。