经过window(Navicat)访问linux中的mysql数据库

Centos安装Mysql数据库

查看咱们的操做系统上是否已经安装了mysql数据库node

[root@centos~]# rpm -qa | grep mysql  // 这个命令就会查看该操做系统上是否已经安装了mysql数据库mysql

 

有的话,咱们就经过 rpm -e 命令 或者 rpm -e --nodeps 命令来卸载掉linux

[root@centos~]# rpm -e mysql  // 普通删除模式sql

[root@centos~]# rpm -e --nodeps mysql  // 强力删除模式,若是使用上面命令删除时,提示有依赖的其它文件,则用该命令能够对其进行强力删除shell

 

经过yum来进行mysql的安装数据库

[root@centos~]# yum list | grep mysqlvim

[root@centos~]# yum install -y mysql-server mysql mysql-devecentos

 

查看刚安装好的mysql-server的版本tomcat

[root@centos~]# rpm -qi mysql-server服务器

 

注意:若是咱们是第一次启动mysql服务,mysql服务器首先会进行初始化的配置

[root@centos~]# service mysqld start

 

初始启动mysql以后再登陆就会很快了

[root@centos~]# service mysqld restart

 

查看mysql服务是否是开机自动启动

[root@centos~]# chkconfig --list | grep mysqld

mysqld             0:关闭    1:关闭    2:关闭    3:关闭    4:关闭    5:关闭    6:关闭

 

经过 chkconfig mysqld on 命令来将其设置成开机启动,这样就不用每次都去手动启动了

[root@centos~]# chkconfig mysqld on

[root@centos~]# chkconfig --list | grep mysql

mysqld             0:关闭    1:关闭    2:启用    3:启用    4:启用    5:启用    6:关闭

 

mysql数据库安装完之后只会有一个root管理员帐号,可是此时的root帐号还并无为其设置密码,在第一次启动mysql服务时,会进行数据库的一些初始化工做,在输出的一大串信息中,咱们看到有这样一行信息 :

[root@centos~]# /usr/bin/mysqladmin -u root password 'new-password'  // root帐号设置密码

 

注意:这个root帐号是mysqlroot帐号,非Linuxroot帐号)

[root@centos~]# mysqladmin -u root password 'root'  // 经过该命令给root帐号设置密码为 root

[root@centos ~]# mysql -u root -p

Mysql数据库的主要配置文件

1./etc/my.cnf 这是mysql的主配置文件

[root@centosetc]# cat my.cnf

[mysqld]

datadir=/var/lib/mysql

socket=/var/lib/mysql/mysql.sock

user=mysql

# Disabling symbolic-links is recommended to prevent assorted security risks

symbolic-links=0

 

[mysqld_safe]

log-error=/var/log/mysqld.log

pid-file=/var/run/mysqld/mysqld.pid

 

/var/lib/mysql   mysql数据库的数据库文件存放位置

咱们的mysql数据库的数据库文件一般是存放在了/ver/lib/mysql这个目录下

[root@centos~]# cd /var/lib/mysql/

[root@centos mysql]# ls -l

总用量 20488

-rw-rw----. 1 mysql mysql 10485760 4月   6 22:01 ibdata1

-rw-rw----. 1 mysql mysql  5242880 4月   6 22:01 ib_logfile0

-rw-rw----. 1 mysql mysql  5242880 4月   6 21:59 ib_logfile1

drwx------. 2 mysql mysql     4096 4月   6 21:59 mysql  // 这两个是mysql数据库安装时默认的两个数据库文件

srwxrwxrwx. 1 mysql mysql        0 4月   6 22:01 mysql.sock

drwx------. 2 mysql mysql     4096 4月   6 21:59 test  // 这两个是mysql数据库安装时默认的两个数据库文件

 

建立一个咱们本身的数据库看一下

mysql> create database ceshi001;

Query OK, 1 row affected (0.00 sec)

 

[root@centos mysql]# ls -l

总用量 20492

-rw-rw----. 1 mysql mysql 10485760 4月   6 22:01 ibdata1

-rw-rw----. 1 mysql mysql  5242880 4月   6 22:01 ib_logfile0

-rw-rw----. 1 mysql mysql  5242880 4月   6 21:59 ib_logfile1

drwx------. 2 mysql mysql     4096 4月   6 21:59 mysql

srwxrwxrwx. 1 mysql mysql        0 4月   6 22:01 mysql.sock

drwx------. 2 mysql mysql     4096 4月   6 21:59 test

drwx------. 2 mysql mysql     4096 4月   6 22:15 ceshi001  // 这个就是咱们刚本身建立的centos数据库

[root@centos mysql]# cd xiaoluo/

[root@centos ceshi001]# ls

db.opt

 

/var/log mysql数据库的日志输出存放位置

咱们的mysql数据库的一些日志输出存放位置都是在/var/log这个目录下

[root@centos ceshi001]# cd

[root@centos ~]# cd /var/log

[root@centos log]# ls

amanda                cron           maillog-20130331   spice-vdagent.log

anaconda.ifcfg.log    cron-20130331  mcelog             spooler

anaconda.log          cups           messages           spooler-20130331

anaconda.program.log  dirsrv         messages-20130331  sssd

anaconda.storage.log  dmesg          mysqld.log         tallylog

anaconda.syslog       dmesg.old      ntpstats           tomcat6

anaconda.xlog         dracut.log     piranha            wpa_supplicant.log

anaconda.yum.log      gdm            pm-powersave.log   wtmp

audit                 httpd          ppp                Xorg.0.log

boot.log              ibacm.log      prelink            Xorg.0.log.old

btmp                  lastlog        sa                 Xorg.1.log

btmp-20130401         libvirt        samba              Xorg.2.log

cluster               luci           secure             Xorg.9.log

ConsoleKit            maillog        secure-20130331    yum.log

 

查看网络端口号为3306mysql数据库是否正在工做:

[root@centos mysql]#netstat -anp|more

 使用Navicat链接Linux

这样就完成了在Centos上安装mysql数据库的操做,以后打开本地window->cmdping一下linux地址看看是否能连上

 

查看虚拟机IP192.168.38.128

     

cmd窗口ping 192.168.38.128,出现以下界面说明是能够的  

  

默认安装linux是只开通了22端口,不能经过3306端口让外界访问,首先要在mysql>中打开权限,在将iptables3306端口打开

mysql> GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY 'MyPassword' WITH GRANT OPTION; FLUSH PRIVILEGES;  // mysql控制台执行命令中的 ‘root’@’%’ 能够这样理解: root是用户名,%是主机名或IP地址,这里的%表明任意主机或IP地址,你也可替换成任意其它用户名或指定惟一的IP地址;’MyPassword’是给受权用户指定的登陆数据库的密码;另外须要说明一点的是我这里的都是受权全部权限,能够指定部分权限

而后直接关闭防火墙也能够.

mysql> flush privileges;

 

检查虚拟机mysql的端口号是否对外开通

好比咱们能用xshell等远程工具链接虚拟机上的linux,是由于开放了22端口查看mysql的端口,在mysql命令行模式下执行如下命令就能够查看,查到的结果是3306

     mysql> show variables like '%port%';

  

  查看虚拟机的3306端口是否开放

  cmd下执行telnet 192.168.38.128 3306

  没法执行,别方,这是由于Windows telnet默认是关闭的

  

  按照红框提示开启telnet

  

  从新打开cmd窗口执行命令,结果是没法链接,这是由于虚拟机上的3306并无对外开放,能够用22的试下效果就知道了

  

  开通虚拟机的3306端口  

  查看虚拟机防火墙的状态

  [root@centos~]# service iptables status

  能够看到目前只有22端口对外开放

  

  编辑防火墙文件打开3306端口

  [root@centos~]# vim /etc/sysconfig/iptables

  模仿22端口开放命令添加如图所示的一行即表示对外开放3306端口  

  

  重启防火墙

  [root@centos~]# service iptables restart  // 能够看到3306已经开放

  

打开Navicat,建立链接到虚拟机:

报错:1045 Access denied for user 'centos-test@'%' (using password: YES)

  是由于在mysql>  GRANT ALL PRIVILEGES ON *.* TO root@"%" IDENTIFIED BY "密码"; 设置的是全部linux中的root帐户 ,而非centos-test帐户

  mysql> flush privileges;

解决办法:

  GRANT ALL PRIVILEGES ON *.* TO centos-test@"%" IDENTIFIED BY "密码"; // 经过该命令容许centos-test的全部帐户经过密码来访问该数据库

  mysql> flush privileges;

 

若是想经过cmd来访问mysql

要在window下安装mysql操做台,而后远程链接虚拟机数据库访问

  端口都开启了,但仍是连不上,看提示说明至少已经关联到mysql,不容许是由于权限不够

 

  我也不用root帐号了,这里从新建立一个帐号并赋予全部权限,以后让权限配置生效,在虚拟机上的mysql命令行模式下执行如下命令

    mysql> create user 'panda'@'%' identified by '123456';

    mysql> grant all on *.* to 'panda'@'%';

    mysql> flush privileges;

  而后从新链接DB

 

附加题:

将mysql目录下bin目录中的mysql.exe放到C:\WINDOWS下,能够执行如下命令链接:mysql -h主机地址 -u用户名 -p用户密码 (注:u与root能够不用加空格,其它也同样) 断开:exit (回车) 建立受权:grant select on 数据库.* to 用户名@登陆主机 identified by \"密码\" 修改密码:mysqladmin -u用户名 -p旧密码 password 新密码 删除受权: revoke select,insert,update,delete om *.* from test2@localhost; 显示数据库:show databases; 显示数据表:show tables; 显示表结构:describe 表名; 建立库:create database 库名; 删除库:drop database 库名; 使用库:use 库名; 建立表:create table 表名 (字段设定列表); 删除表:drop table 表名; 修改表:alter table t1 rename t2 查询表:select * from 表名; 清空表:delete from 表名; 备份表: mysqlbinmysqldump -h(ip) -uroot -p(password) databasename tablename > tablename.sql 恢复表: mysqlbinmysql -h(ip) -uroot -p(password) databasename tablename < tablename.sql(操做前先把原来表删除) 增长列:ALTER TABLE t2 ADD c INT UNSIGNED NOT NULL AUTO_INCREMENT,ADD INDEX (c); 修改列:ALTER TABLE t2 MODIFY a TINYINT NOT NULL, CHANGE b c CHAR(20); 删除列:ALTER TABLE t2 DROP COLUMN c; 备份数据库:mysql\bin\mysqldump -h(ip) -uroot -p(password) databasename > database.sql 
相关文章
相关标签/搜索