CentOS 安装mysql

第一篇:安装和配置MySQL
  第一步:安装MySQL
 
[root@192 local]# yum -y install mysql-server ← 安装MySQL
 
[root@192 local]# yum -y install php-mysql    ← 安装php-mysql
 
  第二步:配置MySQL
 
[root@192 local] #vim /etc/my.cnf             ← 编辑MySQL的配置文件
 
[mysqld]
datadir=/var/lib/mysql
socket=/var/lib/mysql/mysql.sock
# Default to using old password format for compatibility with mysql 3.x
# clients (those using the mysqlclient10 compatibility package).
old_passwords=1  ← 找到这一行,在这一行的下面添加新的规则,让MySQL的默认编码为UTF-8
default-character-set = utf8  ← 添加这一行
 
然后在配置文件的文尾填加如下语句:
 
[mysql]
default-character-set = utf8
 
 
 
       第二篇:启动MySQL和初始环境设定
 
 
  第一步:启动MySQL服务
 
[root@192 local]#chkconfig mysqld on ← 设置MySQL服务随系统启动自启动
 
[root@192 local]#chkconfig --list mysqld ← 确认MySQL自启动
mysqld          0:关闭  1:关闭  2:启用  3:启用  4:启用  5:启用  6:关闭
 
                                              ← 如果2--5为启用(或on)的状态就OK
 
[root@192 local]#/etc/rc.d/init.d/mysqld start  ← 启动MySQL服务
 
初始化 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 192.168.0.1 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 test the MySQL daemon with mysql-test-run.pl
cd mysql-test ; perl mysql-test-run.pl
 
Please report any problems with the /usr/bin/mysqlbug script!
 
The latest information about MySQL is available on the web at
http://www.mysql.com
Support MySQL by buying support/licenses athttp://shop.mysql.com
                                                           [确定]
启动 mysqld:                                              [确定]
 
 
 
 
  第二步:MySQL初始环境设定
 
  [1]  为MySQL的root用户设置密码
 
MySQL在刚刚被安装的时候,它的root用户是没有被设置密码的。首先来设置MySQL的root密码。
 
[root@192 local]#mysql -u root  ← 在没设置密码之时,用root用户登录MySQL服务器
Welcome to the MySQL monitor.  Commands end with ; or \g.
Your MySQL connection id is 2
Server version: 5.0.95 Source distribution
 
Copyright (c) 2000, 2011,  Oracle and/or its affiliates. All rights reserved.
 
Oracle is a registered trademark of Oracle Corporation and/or its
affiliates. Other names may be trademarks of their respective
owners.
 
Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.
 
 
 
mysql> select user,host,password from mysql.user;  ← 查看用户信息
mysql> select user,host,password from mysql.user;
+------+-------------+----------+
| user | host        | password |
+------+-------------+----------+
| root | localhost   |          | 
| root | 192.168.0.1 |          | 
| root | 127.0.0.1   |          | 
|      | localhost   |          | 
|      | 192.168.0.1 |          | 
+------+-------------+----------+
5 rows in set (0.03 sec)
 
mysql> set password for root@localhost=password ('在这里填入root密码');  ← 设置root密码
 
譬如,在我的 系统中,我是如下设置:
 
mysql> set password for root@localhost=password ('wangyun');
 
Query OK, 0 rows affected (0.01 sec)
 
mysql> set password for root@192.168.0.1=password ('wangyun');
Query OK, 0 rows affected (0.01 sec)
 
mysql> set password for root@127.0.0.1=password ('wangyun');
Query OK, 0 rows affected (0.01 sec)
 
 
 
mysql> select user,host,password from mysql.user;  ← 查看用户信息
 
+------+-------------+------------------+
| user | host        | password         |
+------+-------------+------------------+
| root | localhost   | 5f2dfe4b07af795b | 
| root | 192.168.0.1 | 5f2dfe4b07af795b | 
| root | 127.0.0.1   | 5f2dfe4b07af795b | 
|      | localhost   |                  | 
|      | 192.168.0.1 |                  | 
+------+-------------+------------------+
5 rows in set (0.01 sec)
 
mysql> exit  ← 退出MySQL服务器
Bye
 
 
 
  [2] 测试设置的root密码是否生效
 
 
 
[root@192 local]# mysql -u root      ← 通过空密码用root登录
ERROR 1045 (28000): Access denied for user 'root'@'localhost' (using password: NO)
                                     ← 出现此错误信息说明密码设置成功
 
[root@192 local]# mysql -u root-p    ← 通过密码用root登录
Enter password: ← 在这里输入密码
 
 
Welcome to the MySQL monitor.  Commands end with ; or \g.  ← 确认用密码能够成功登录
Your MySQL connection id is 5
Server version: 5.0.95 Source distribution
 
...  ...
 
Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.
 
[root@192 local]#mysql -u root -h 127.0.0.1 -p ← 通过密码用root登录
Enter password:   ← 在这里输入密码
Welcome to the MySQL monitor.  Commands end with ; or \g.← 确认用密码能够成功登录
Your MySQL connection id is 13
Server version: 5.0.95 Source distribution
 
......
 
Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.
 
mysql> exit  ← 退出MySQL服务器
Bye
 
 
 
   [3] 删除匿名用户
 
 
 
在MySQL刚刚被安装后,存在用户名、密码为空的用户。这使得数据库服务器有无需密码被登录的可能性。为消除隐患,将匿名用户删除。
 
 
 
[root@192 local]# mysql -u root -p; ← 通过密码用root登录
Enter password:    ← 在这里输入密码
 
 
 
mysql> select user,host from mysql.user;
+------+-------------+
| user | host        |
+------+-------------+
| root | 127.0.0.1   | 
|      | 192.168.0.1 | 
| root | 192.168.0.1 | 
|      | localhost   | 
| root | localhost   | 
+------+-------------+
5 rows in set (0.03 sec)
 
 
 
mysql> delete from mysql.user where user=''; ← 删除匿名用户
 
Query OK, 2 rows affected (0.04 sec)
 
 
 
mysql> select user,host from mysql.user;  ← 查看用户信息
 
+------+-------------+
| user | host        |
+------+-------------+
| root | 127.0.0.1   | 
| root | 192.168.0.1 | 
| root | localhost   | 
+------+-------------+
3 rows in set (0.00 sec)
 
 
 
mysql> flush privileges;  ← 刷新,使以上操作生效
 
mysql> exit;   ←退出MySQL服务器
Bye


CentOS下mysql开启远程连接  

CentOS系统安装好MySQL后,默认情况下不支持用户通过非本机连接上数据库服务器,下面是解决方法:

1、在控制台执行 mysql -u root -p mysql,系统提示输入数据库root用户的密码,输入完成后即进入mysql控制台,这个命令的第一个mysql是执行命令,第二个mysql是系统数据名称,不一样的。

2、在mysql控制台执行 GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY 'MyPassword' WITH GRANT OPTION;

FLUSH PRIVILEGES; 

3、在mysql控制台执行命令中的 'root'@'%' 可以这样理解: root是用户名,%是主机名或IP地址,这里的%代表任意主机或IP地址,你也可替换成任意其它用户名或指定唯一的IP地址;'MyPassword'是给授权用户指定的登录数据库的密码;另外需要说明一点的是我这里的都是授权所有权限,可以指定部分权限,GRANT具体操作详情见:http://dev.mysql.com/doc/refman/5.1/en/grant.html 

4、不放心的话可以在mysql控制台执行 select host, user from user; 检查一下用户表里的内容

到此还是在客户端还是连接不上

 

此时检查下防火墙是否开启:

/etc/init.d/iptables status

会得到一系列信息,说明防火墙开着。则关闭:

/etc/init.d/iptables stop 

永久关闭::

chkconfig --level 35 iptables off 

再次连接,可以了

或者不关闭防火墙:
iptables -A INPUT -p tcp -m state --state NEW -m tcp --dport 3306 -j ACCEPT
service iptables save
service iptables restart

或:
第一步:

[root@localhost ~]# vi /etc/sysconfig/iptables

在打开的文件中,插入:

-A INPUT -m state --state NEW -m tcp -p tcp --dport 3306 -j ACCEPT

第二步:

重启防火墙

 

[root@localhost ~]# service iptables restart


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值