计划在一台vmware fedora(环境A)上建立mysql客户端,另一个vmware fedora 环境(环境B)上搭建mysql-server,这样环境A可以访问环境B mysql数据库,同时进行linux下数据库程序开发验证,这里简要记录安装过程。
1、在环境B上直接尝试登陆mysql数据库
------------------------------------------------------------------------------------
[root@localhost ~]# mysql -uroot -p -hlocalhost
Enter password:
ERROR 2002 (HY000): Can't connect to local MySQL server through socket '/var/lib/mysql/mysql.sock' (2)
------------------------------------------------------------------------------------
查询本地环境是否安装对应的软件包:
[root@localhost ~]# rpm -qa | grep mysql-server
[root@localhost ~]#
尚未安装
直接通过yum安装:
------------------------------------------------------------------------------------
[root@localhost admin]#
[root@localhost admin]# yum install mysql-server
Loading "installonlyn" plugin
Setting up Install Process
Parsing package install arguments
Resolving Dependencies
--> Running transaction check
---> Package mysql-server.i386 0:5.0.45-6.fc7 set to be updated
--> Processing Dependency: perl(DBI) for package: mysql-server
--> Processing Dependency: perl-DBI for package: mysql-server
--> Processing Dependency: mysql = 5.0.45-6.fc7 for package: mysql-server
--> Processing Dependency: perl-DBD-MySQL for package: mysql-server
--> Restarting Dependency Resolution with new changes.
--> Running transaction check
---> Package mysql.i386 0:5.0.45-6.fc7 set to be updated
---> Package perl-DBI.i386 0:1.53-2.fc7 set to be updated
---> Package perl-DBD-MySQL.i386 0:3.0008-1.fc7 set to be updated
--> Processing Dependency: mysql-libs = 5.0.45-6.fc7 for package: mysql
--> Restarting Dependency Resolution with new changes.
--> Running transaction check
---> Package mysql-libs.i386 0:5.0.45-6.fc7 set to be updated
Dependencies Resolved
=============================================================================
Package Arch Version Repository Size
=============================================================================
Installing:
mysql-server i386 5.0.45-6.fc7 updates 9.8 M
Installing for dependencies:
mysql i386 5.0.45-6.fc7 updates 2.7 M
perl-DBD-MySQL i386 3.0008-1.fc7 fedora 148 k
perl-DBI i386 1.53-2.fc7 fedora 611 k
Updating for dependencies:
mysql-libs i386 5.0.45-6.fc7 updates 1.5 M
Transaction Summary
=============================================================================
Install 4 Package(s)
Update 1 Package(s)
Remove 0 Package(s)
Total download size: 15 M
Is this ok [y/N]: y
Downloading Packages:
(1/4): mysql-libs-5.0.45- 100% |=========================| 1.5 MB 01:13
(2/4): mysql-server-5.0.4 100% |=========================| 9.8 MB 06:07
(3/4): perl-DBD-MySQL-3.0 100% |=========================| 148 kB 00:03
(4/4): mysql-5.0.45-6.fc7 100% |=========================| 2.7 MB 01:50
Running Transaction Test
Finished Transaction Test
Transaction Test Succeeded
Running Transaction
Updating : mysql-libs ######################### [1/6]
Installing: perl-DBI ######################### [2/6]
Installing: mysql ######################### [3/6]
Installing: perl-DBD-MySQL ######################### [4/6]
Installing: mysql-server ######################### [5/6]
Cleanup : mysql-libs ######################### [6/6]
Installed: mysql-server.i386 0:5.0.45-6.fc7
Dependency Installed: mysql.i386 0:5.0.45-6.fc7 perl-DBD-MySQL.i386 0:3.0008-1.fc7 perl-DBI.i386 0:1.53-2.fc7
Dependency Updated: mysql-libs.i386 0:5.0.45-6.fc7
Complete!
[root@localhost admin]#
安装之后继续登陆,发现还是一样的提示
查服务是否启动:
[root@localhost ~]# service mysqld status
没有启动,
启动守护进程服务:
[root@localhost ~]# service mysqld restart
2、服务启动后登陆
------------------------------------------------------------------------------------
[root@localhost ~]#mysql -uroot -proot -hlocalhost
mysql ERROR 1045: Access denied for user: (Using password: YES)
------------------------------------------------------------------------------------
后来发现时默认安装的mysql-server root用户密码为空,上面所用密码错误导致的
尝试如下登陆:
[root@localhost ~]#mysql -uroot -p -hlocalhost
OK,登陆成功
修改root登陆密码方法如下:
3、在环境A上登陆环境B上的mysql数据库
------------------------------------------------------------------------------------
[root@localhost ~]# mysql -uroot -p -h192.168.62.129
Enter password:
ERROR 1130 (00000): Host '192.168.62.128' is not allowed to connect to this MySQL server
[root@localhost ~]#
------------------------------------------------------------------------------------
这是因为mysql指定了某个账户只能由某个服务器登陆,可以通过在环境B上进行下面非配置解决:
3.1、修改root账户,只有192.168.62.128登陆root,则在环境B登陆mysql,进行如下配置:
------------------------------------------------------------------------------------
[root@localhost ~]# mysql -uroot -p -hlocalhost
Enter password:
Welcome to the MySQL monitor. Commands end with ; or \g.
Your MySQL connection id is 4
Server version: 5.0.45 Source distribution
Type 'help;' or '\h' for help. Type '\c' to clear the buffer.
mysql> show databases;
+--------------------+
| Database |
+--------------------+
| information_schema |
| mysql |
| test |
+--------------------+
3 rows in set (0.00 sec)
mysql> use mysql;
Reading table information for completion of table and column names
You can turn off this feature to get a quicker startup with -A
Database changed
mysql> show tables;
+---------------------------+
| Tables_in_mysql |
+---------------------------+
| columns_priv |
| db |
| func |
| help_category |
| help_keyword |
| help_relation |
| help_topic |
| host |
| proc |
| procs_priv |
| tables_priv |
| time_zone |
| time_zone_leap_second |
| time_zone_name |
| time_zone_transition |
| time_zone_transition_type |
| user |
+---------------------------+
17 rows in set (0.00 sec)
mysql> update user set host='%' where user='root';
ERROR 1062 (23000): Duplicate entry '%-root' for key 1
mysql> describe user;
+-----------------------+-----------------------------------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+-----------------------+-----------------------------------+------+-----+---------+-------+
| Host | char(60) | NO | PRI | | |
| User | char(16) | NO | PRI | | |
| Password | char(41) | NO | | | |
| Select_priv | enum('N','Y') | NO | | N | |
| Insert_priv | enum('N','Y') | NO | | N | |
| Update_priv | enum('N','Y') | NO | | N | |
| Delete_priv | enum('N','Y') | NO | | N | |
| Create_priv | enum('N','Y') | NO | | N | |
| Drop_priv | enum('N','Y') | NO | | N | |
| Reload_priv | enum('N','Y') | NO | | N | |
| Shutdown_priv | enum('N','Y') | NO | | N | |
| Process_priv | enum('N','Y') | NO | | N | |
| File_priv | enum('N','Y') | NO | | N | |
| Grant_priv | enum('N','Y') | NO | | N | |
| References_priv | enum('N','Y') | NO | | N | |
| Index_priv | enum('N','Y') | NO | | N | |
| Alter_priv | enum('N','Y') | NO | | N | |
| Show_db_priv | enum('N','Y') | NO | | N | |
| Super_priv | enum('N','Y') | NO | | N | |
| Create_tmp_table_priv | enum('N','Y') | NO | | N | |
| Lock_tables_priv | enum('N','Y') | NO | | N | |
| Execute_priv | enum('N','Y') | NO | | N | |
| Repl_slave_priv | enum('N','Y') | NO | | N | |
| Repl_client_priv | enum('N','Y') | NO | | N | |
| Create_view_priv | enum('N','Y') | NO | | N | |
| Show_view_priv | enum('N','Y') | NO | | N | |
| Create_routine_priv | enum('N','Y') | NO | | N | |
| Alter_routine_priv | enum('N','Y') | NO | | N | |
| Create_user_priv | enum('N','Y') | NO | | N | |
| ssl_type | enum('','ANY','X509','SPECIFIED') | NO | | | |
| ssl_cipher | blob | NO | | | |
| x509_issuer | blob | NO | | | |
| x509_subject | blob | NO | | | |
| max_questions | int(11) unsigned | NO | | 0 | |
| max_updates | int(11) unsigned | NO | | 0 | |
| max_connections | int(11) unsigned | NO | | 0 | |
| max_user_connections | int(11) unsigned | NO | | 0 | |
+-----------------------+-----------------------------------+------+-----+---------+-------+
37 rows in set (0.12 sec)
------------------------------------------------------------------------------------
mysql>use mysql;
mysql>update user set host='192.168.62.128' where user='root';
mysql>flush privileges;
------------------------------------------------------------------------------------
3.2、修改root账户,任意用户登陆root,则在环境B登陆mysql,进行如下配置:
------------------------------------------------------------------------------------
mysql>use mysql;
mysql>update user set host='%' where user='root';
mysql>flush privileges;
------------------------------------------------------------------------------------
3.3、通过grant配置登陆权限
---------------------------------------------------------------------------------------------
命令格式:
grant 权限1,权限2,…,权限n on 数据库名称.表名称 to 用户名@用户地址 identified by ‘连接口令’;
权限包括:create,drop,insert,update,select,reload,delete,references,shutdown,
grant,index,alter,process等。
----------------------------------------------------------------------------------------------
命令:mysql>grant all privileges on test.* to identified by ‘roottoor′;
|------------------------------------------------------------------------------------
目的:设定用户root分配可对数据库test所有表进行所有的操作权限,同时设定口令为roottoor。
---------------------------------------------------------------------------------------------
命令:mysql>grant select,insert,update on test.* to identified by
′123456′;
mysql>flush privileges;
|--------------------------------------------
目的:设定192.168.62.128用户moo分配可对数据库test所有表进行select,insert,update等操作权限,同时设定口令为123456。
至此,可以在环境A的环境上进行登陆环境B的mysql server了。
|-----------------------------------------设置之前--------------------------------------------
[root@localhost ~]#
[root@localhost ~]# mysql -uroot -p -h192.168.62.129
Enter password:
ERROR 1130 (00000): Host '192.168.62.128' is not allowed to connect to this MySQL server
[root@localhost ~]#
|----------------------------------------设置之后--------------------------------------------
在环境A上:
[root@localhost ~]# ifconfig
eth0 Link encap:Ethernet HWaddr 00:0C:29:E5:66:83
inet addr:192.168.62.128 Bcast:192.168.62.255 Mask:255.255.255.0
inet6 addr: fe80::20c:29ff:fee5:6683/64 Scope:Link
UP BROADCAST RUNNING MULTICAST MTU:1500 Metric:1
RX packets:20755 errors:0 dropped:0 overruns:0 frame:0
TX packets:17391 errors:0 dropped:0 overruns:0 carrier:0
collisions:0 txqueuelen:1000
RX bytes:11540148 (11.0 MiB) TX bytes:3097607 (2.9 MiB)
Interrupt:18 Base address:0x2024
lo Link encap:Local Loopback
inet addr:127.0.0.1 Mask:255.0.0.0
inet6 addr: ::1/128 Scope:Host
UP LOOPBACK RUNNING MTU:16436 Metric:1
RX packets:10167 errors:0 dropped:0 overruns:0 frame:0
TX packets:10167 errors:0 dropped:0 overruns:0 carrier:0
collisions:0 txqueuelen:0
RX bytes:90759697 (86.5 MiB) TX bytes:90759697 (86.5 MiB)
[root@localhost ~]#
[root@localhost ~]# mysql -uroot -p -h192.168.62.129
Enter password:
Welcome to the MySQL monitor. Commands end with ; or \g.
Your MySQL connection id is 9
Server version: 5.0.45 Source distribution
Type 'help;' or '\h' for help. Type '\c' to clear the buffer.
mysql>
-------------------------------------------END--------------------------------------------
阅读(1312) | 评论(0) | 转发(0) |