mysql install in ubuntu

mysql server 5.1;
mysql Navigator
转载请注明出处:http://club.topsage.com/thread-2208018-1-1.html

如果你是LAMP平台开发人员,或者你是单纯想学MySQL数据库,安装完Ubuntu Linux后,接下了就得考虑如果安装Oracle (Sun) MySQL了,之后还要新建数据库用户,为数据库连接作准备。

Sun被Oracle收购后,MySQL也归属Oracle公司,不过,在Ubuntu里社区开源版的MySQL依然可以通过命令免费安装。安装MySQL前,我们首先更新一下系统,打开终端后执行如下命令:

   1. $sudo apt-get update
   2. $sudo apt-get upgrade

复制代码
安装MySQL数据库

在终端中执行如下命令安装MySQL数据库服务器及客户端软件:

   1. $sudo apt-get install mysql-server mysql-common mysql-client

复制代码
安装过程中,程序会要求为root用户输入密码。几分钟后就能安装完成。

如果你打算用PHP程序或是Perl连接你的MySQL数据库,这时候需要我们为Apache服务器安装php及perl的相关模块:

PHP的:

   1. $sudo apt-get install php5-mysql
   2. $sudo /etc/init.d/apache2 restart

复制代码
Perl5相关模块:

   1. $sudo apt-get install libdbd-mysql-perl

复制代码
如何连接MySQL数据库服务器?

当然是通过mysql命令连接最为方便快捷了,如果不太熟悉mysql命令,可以下载一个基于Web的MySQL管理工具phpMyAdmin。

打开终端,输入如下命令并执行:

   1. $mysql -u root -p

复制代码
mysql命令的-p参数要求输入密码。

    Enter password:
    Welcome to the MySQL monitor.  Commands end with ; or \g.
    Your MySQL connection id is 107
    Server version: 5.1.41-3ubuntu12.3 (Ubuntu)

    Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.

    mysql>



看到上面的提示符就说明已经成功登录MySQL数据库服务器了,这个时候就可以对数据库及其中的表进行操作了。下载看几个常用的MySQL命令:

任务1:显示数据库列表

执行如下命令:

mysql> show databases;

你会得到类似如下的数据库列表

+--------------------+
| Database           |
+--------------------+
| information_schema |
| mysql              |
| wiki               |
| wikidb             |
| wpmu               |
+--------------------+
5 rows in set (0.02 sec)

mysql>

任务2:新建数据库

新建一个名称为 myapps 的数据库,执行:

mysql> create database myapps;

输出信息:

Query OK, 1 row affected (0.00 sec)

任务3:为myapps数据库添加新用户

mysql> GRANT ALL ON myapps.* TO vivek@localhost IDENTIFIED BY 'Add-Your-Password-Here';

查看日志文件

默认配置文件下MySQL的日志文件保存在 /var/log/mysql/error.log,查看日志内容:

$tail -f /var/log/mysql/error.log
$grep 'something' /var/log/mysql/error.log

更改MySQL配置

默认配置文件存储在/etc/mysql/my.cnf,使用vi编辑器打开之:

$sudo vi /etc/mysql/my.cnf

如果想把MySQL网络绑定到本机(192.168.1.5),只要在my.cnf配置文件中加入如下配置项:

   1. bind-address = 192.168.1.5

复制代码
保存并关闭vi编辑器。

如何启动、停止、重启MySQL服务器?

执行如下命令以重启、停止、启动MySQL服务器:

   1. $sudo service mysql restart
   2. $sudo service mysql stop
   3. $sudo service mysql start

复制代码
命令执行时可能会出现如下的输出信息:

mysql start/running, process 4930

也可以使用如下的命令格式执行这些操作:

   1. $sudo /etc/init.d/mysql start
   2. $sudo /etc/init.d/mysql stop
   3. $sudo /etc/init.d/mysql restart

==================================

[转载]MySql实现远程连接
(2011-09-14 17:32:58)
转载▼
标签:
it
分类: 数据库
1、进入mysql,创建一个新用户root,密码为root:

   格式:grant 权限 on 数据库名.表名 to 用户@登录主机 identified by "用户密码";
           grant select,update,insert,delete on *.* to [email protected] identified by "root";

   原先数据表结构

    mysql> use mysql;
    Database changed
    mysql> select host,user,password from user;
    +-----------+------+-------------------------------------------+
    | host      | user | password                                  |
    +-----------+------+-------------------------------------------+
    | localhost | root | *81F5E21E35407D884A6CD4A731AEBFB6AF209E1B |
    +-----------+------+-------------------------------------------+

   执行上述语句后结果

    mysql> use mysql;
    Database changed
    mysql> select host,user,password from user;
    +--------------+------+-------------------------------------------+
    | host         | user | password                                  |
    +--------------+------+-------------------------------------------+
    | localhost    | root | *81F5E21E35407D884A6CD4A731AEBFB6AF209E1B |
    | 192.168.1.12 | root | *81F5E21E35407D884A6CD4A731AEBFB6AF209E1B |
    +--------------+------+-------------------------------------------+
    2 rows in set (0.00 sec)



   可以看到在user表中已有刚才创建的root用户。host字段表示登录的主机,其值可以用IP,也可用主机名,

   (1)有时想用本地IP登录,那么可以将以上的Host值改为自己的Ip即可。

2、实现远程连接(授权法)

   将host字段的值改为%就表示在任何客户端机器上能以root用户登录到mysql服务器,建议在开发时设为%。 
   update user set host = ’%’ where user = ’root’;

   将权限改为ALL PRIVILEGES

    mysql> use mysql;
    Database changed
    mysql> grant all privileges  on *.* to root@'%' identified by "root";
    Query OK, 0 rows affected (0.00 sec)

    mysql> select host,user,password from user;
    +--------------+------+-------------------------------------------+
    | host         | user | password                                  |
    +--------------+------+-------------------------------------------+
    | localhost    | root | *81F5E21E35407D884A6CD4A731AEBFB6AF209E1B |
    | 192.168.1.12 | root | *81F5E21E35407D884A6CD4A731AEBFB6AF209E1B |
    | %            | root | *81F5E21E35407D884A6CD4A731AEBFB6AF209E1B |
    +--------------+------+-------------------------------------------+
    3 rows in set (0.00 sec)

这样机器就可以以用户名root密码root远程访问该机器上的MySql.

3、实现远程连接(改表法)

use mysql;

update user set host = '%' where user = 'root';

这样在远端就可以通过root用户访问Mysql.
但任不行,最后
=========
Ubuntu10.04上自带的MySQL,执行了
root@ubuntu:~#sudo apt-get install mysql
安装完mysql-server

启动mysql
root@ubuntu:~#/etc/init.d/mysql start

本地可以连接进入数据库。
root@ubuntu:~#mysql -uroot -p

设置了远程访问权限:
mysql> grant all PRIVILEGES on *.* to admin@’%’ identified by ‘123456′;
Query OK, 0 rows affected (0.04 sec)
=====================
mysql> grant all privileges on myapps.* to 'net5100'@'%' identified by '123456' with grant option;

mysql> use information_schema
mysql> select * from user_privileges;
查询到有下面的结果:'admin’@'%',说明mysql已经授权远程连接。



Ubuntu上查看Mysql网络连接:
root@ubuntu:~# netstat -an |grep 3306
tcp 0 0 127.0.0.1:3306 0.0.0.0:* LISTEN
本地端口也在监听

root@ubuntu:~# ufw status
Firewall not loaded
本地防火墙未打开

后来在网上找到一个解决办法:
查看 /etc/mysql/my.cnf找到bind-address才发现配置的是 127.0.0.1(bind-address=127.0.0.1),直接改为bind-address=192.168.0.xxx(本机ip),然 后再查看3306端口打开了,ok,可以正常连接了
====mysql import from sql file=====
1,mysql> use myapps;
\. shortword source
2,mysql> \. /home/jimmy/myapps.sql

mysql> \. /home/jimmy/sqlscripts/mysql/jpetstore-mysql-schema.sql
mysql> \. /home/jimmy/sqlscripts/mysql/jpetstore-mysql-dataload.sql


====mysql export db into a sql file=====
jimmy@jimmy:~$ mysqldump -u jimmy -p myapps>/home/jimmy/myapps_export.sql;
Enter password:


=======connect mysql======
jimmy@jimmy:~$ mysql -h 10.36.64.159 -u jimmy -p
Enter password:123456
mysql> show database;
mysql> use myapps;

猜你喜欢

转载自hunter090730.iteye.com/blog/1683476