centOS安装mysql---glibc方式

写在前面:

首先,centos是自己集成mysql的。但是我要用的服务器人家没给装。

其次,centos是可以yum安装mysql的,我很高兴而且轻松的用yum把mysql安装上了。但是,运行的时候很沮丧。yum安装的mysql,当再装SQLAlchemy的时候,报了满屏的错误。我看着满屏的各种错无从下手。本来mysql就不熟。

最后,只好去mysql的网站,down下来源码包,一点一点的安装下来。整整费了我一天。下面我把这的过程记录下来,以后用就方便了。

下载mysql:

http://downloads.mysql.com/archives.php

选择一个mysql的版本,之后一定要看好,下glibc的。如:mysql-5.0.90-linux-i686-glibc23.tar.gz

本例中下载到了/media目录下,这个不是好习惯...

▲安装mysql:

下面是linux命令

[plain] view plain copy

  1. :$ sudo groupadd mysql
  2. :$ sudo useradd -g mysql mysql
  3. :$ cd /usr/local
  4. :$ tar zvxf /media/mysql-5.0.90-linux-i686-glibc23.tar.gz

[plain] view plain copy

  1. :$ mv mysql-5.0.90-linux-i686-glibc23 mysql

[plain] view plain copy

  1. :$ cd mysql
  2. :$ sudo chown -R mysql .
  3. :$ sudo chgrp -R mysql .
  4. :$ scripts/mysql_install_db --user=mysql  --basedir=/usr/local/mysql
  5. :& cd ..
  6. :$ sudo chown -R root mysql .
  7. :$ cd mysql
  8. :$ sudo chown -R mysql data
  9. :$ bin/mysqld_safe --basedir=/usr/local/mysql --user=mysql &

至此,mysql安装成功。

因为在运行状态,我没有ctrl-c,只好再开一个ssh窗口...

▲为mysql的root用户添加密码

下面是linux命令

[c-sharp] view plain copy

  1. cd /usr/local/mysql/bin ./mysql -u root  

进入mysql后:

[c-sharp] view plain copy

  1. mysql>  GRANT ALL PRIVILEGES ON *.* TO [email protected] IDENTIFIED BY "chang";

其实是设置了root的localhost的密码为chang
显示执行成功,然后exit退出mysql。

之后,再次登录mysql,这次要用密码了:

[c-sharp] view plain copy

  1. cd /usr/local/mysql/bin./mysql -u root -p

输入密码chang之后,可以正常登录,如下:

Welcome to the MySQL monitor.  Commands end with ; or /g.
Your MySQL connection id is 1
Server version: 5.0.90 MySQL Community Server (GPL)

Type ‘help;‘ or ‘/h‘ for help. Type ‘/c‘ to clear the current input statement.

查看一下用户信息:

[c-sharp] view plain copy

  1. mysql> select user,host,password from mysql.user;

结果如下:

+------+-----------+----------+
| user | host      | password |
+------+-----------+----------+
| root | localhost |  *F05D019BA3BEC01CA9FBD4141E4EA57A28EF3EDF  |   ← (root密码为chang) 
| root | linux        |            |   ← (root密码为空) 
| root | 127.0.0.1 |           |   ← (root密码为空) 
|        | localhost  |           | 
+------+-----------+----------+

分别更改它们的密码:

[c-sharp] view plain copy

  1. mysql> set password for [email protected]=password(‘chang‘);

[c-sharp] view plain copy

  1. mysql> set password for [email protected]=password(‘chang‘); 

[c-sharp] view plain copy

  1. mysql> set password for [email protected]=password(‘chang‘); 

再次查看用户信息会发现已经更改过来。

然后退出mysql。

▲把mysql做成服务

[c-sharp] view plain copy

  1. sudo cp /usr/local/mysql/support-files/mysql.server /etc/init.d/mysql

启动mysql服务

[c-sharp] view plain copy

  1. sudo /etc/init.d/mysql start

这时候就可以重启机器试试了
重启后再登陆mysql,发现可以登陆。服务制作成功!

▲配置mysql

[c-sharp] view plain copy

  1. vi /etc/my.cnf

(注释:如果没有自动生成my.cnf文件,那么:安装完的mysql包下有个support-files文件夹,其中有my-huge.cnf等,将my-huge copy一份,改名为my.cnf,将其适当地修改(当然是根据你的数据库配置)然后copy至/etc/my.cnf)

打开my.cnf后

找到[client] 添加: 
default-character-set = utf8      # 默认字符集为utf8

找到[mysqld] 添加:
default-character-set = utf8       #默认字符集为utf8
init_connect = ‘SET NAMES utf8‘ #设定连接mysql数据库时使用utf8编码,以让mysql数据库为utf8运行

修改好后,重新启动即可.
我这里是重启了mysql的服务:

[c-sharp] view plain copy

  1. sudo /etc/init.d/mysql restart

(有一次找不到sock,这样重启两次服务之后居然可以了!!!汗。)

之后进入mysql,查一下是否更改了字符集:

[c-sharp] view plain copy

  1. cd /usr/local/mysql/bin./mysql -u root -p

[c-sharp] view plain copy

  1. mysql> show variables like ‘character%‘;

出现下面的画面:

+--------------------------+----------------------------------------+
| Variable_name            | Value                                  |
+--------------------------+----------------------------------------+
| character_set_client     | utf8                                   | 
| character_set_connection | utf8                                   | 
| character_set_database   | utf8                                   | 
| character_set_filesystem | binary                                 | 
| character_set_results    | utf8                                   | 
| character_set_server     | utf8                                   | 
| character_set_system     | utf8                                   | 
| character_sets_dir       | /usr/local/mysql/share/mysql/charsets/ | 
+--------------------------+----------------------------------------+

好,数据库语言完毕。

▲打开mysql的远程访问
mysql默认是不允许远程访问的。
用密码登陆mysql,可以正常登陆,但是换台机器用工具连,就报错:
ERROR 1130: Host 192.168.1.6 is not allowed to connect to this MySQL server

方法: 改表法。mysql默认是不允许远程访问的,只能在localhost访问。这个时候只要在localhost的那台电脑,登入mysql后,更改 “mysql” 数据库里的 “user” 表里的 “host” 项,从”localhost”改成”%”

mysql -u root -p
Enter password: chang
mysql>use mysql;
mysql>update user set host = ‘%‘ where user = ‘root‘;  //可能会报错
mysql>flush privileges; 
mysql>select host,user from user where user=‘root‘;

执行完上面的,就可以远程连接了!

注释:

update user set host = ‘%‘ where user = ‘root‘; //这个命令执行错误时,可能会报错:
ERROR 1062 (23000): Duplicate entry ‘%-root‘ for key 1;
解决方法:
1,不用管它。呵呵。
2,改成这样执行
update user set host=‘%‘ where user=‘root‘ and host=‘localhost‘;
也就是把localhost改成了所有主机。

---------------------------------------------------
之后运行app程序,报错:
ImportError: libmysqlclient_r.so.15: cannot open shared object file: No such file or directory

解决办法是把/usr/local/mysql/lib下的
libmysqlclient_r.so.15
拷贝到/usr/lib解决。

至此,mysql安装配置完毕!

================= 我是华丽的分割线 ========================

----------------------------------------------------
■附注:
附注1: 重启和关闭mysql服务
重启mysql服务
:$ sudo /etc/init.d/mysql restart
关闭mysql服务
:$ sudo /etc/init.d/mysql stop 
----------------------------------------------------
附注2: 非服务状态下,启动和停止mysql
启动mysql
代码: 
:& cd /usr/local/mysql
:& bin/mysqld_safe --basedir=/usr/local/mysql --user=mysql &

停止mysql
代码: 
:& cd /usr/local/mysql
:$ bin/mysqladmin -uroot -ppassw0rd shutdown

----------------------------------------------------
附注3: mysql命令行中文显示?号
mysql> set names utf8;

---------------------------------------------------
附注4: mysql的数据库存放路径
/var/lib/mysql

---------------------------------------------------
附注5: 从mysql中导出和导入数据
mysqldump 数据库名 > 文件名 #导出数据库
mysqladmin create 数据库名 #建立数据库
mysql 数据库名 < 文件名 #导入数据库

---------------------------------------------------
附注6: 修改mysql的root口令
sudo mysqladmin -u root -p password ‘你的新密码‘

或者:括号里是新密码
use mysql; 
update user set Password=password(‘chang‘) where User=‘root‘; 
flush privileges;

---------------------------------------------------
附注7: 忘了mysql的root口令怎么办
sudo /etc/init.d/mysql stop
sudo mysqld_safe --skip-grant-tables &
sudo mysqladmin -u user password ‘newpassword
sudo mysqladmin flush-privileges

---------------------------------------------------
附注8: 输入要登录的mysql主机
./mysql -u root -h 127.0.0.1 -p

原文地址:https://www.cnblogs.com/405845829qq/p/8297321.html

时间: 2024-11-09 03:12:51

centOS安装mysql---glibc方式的相关文章

CentOS安装MySQL问题汇总

遇到的错误 ERROR 1045 (28000): Access denied for user 'root'@'localhost' (using password: NO) denied for user 'root'@'localhost' (using password: NO) 描述:刚安装完MySQL,第一次登陆. [[email protected] ~]$ mysql -u root -p Enter password: #我记得root初始是没密码的,这句直接回车 ERROR

centos 安装mysql 5.5.12

1.安装gcc-c++  gcc make cmake编译器 2.安装ncurses 3.添加用户组 groupadd mysql useradd -r -g mysql mysql 4.安装 tar -zxvf mysql-5.5.12.tar.gz cd mysql-5.5.12 cmake -DCMAKE_INSTALL_PREFIX=/usr/local/mysql -DMYSQL_UNIX_ADDR=/data/mysql/mysql.sock -DDEFAULT_CHARSET=ut

虚拟机centos安装mysql遇到 Couldn‘t resolve host ‘mirror

网上查了一下说是DNS服务器错误.于是修改一下 /etc/resolv.conf添加一个nameserver 8.8.8.8完成虚拟机centos安装mysql遇到 Couldn't resolve host 'mirror安装MySql server:1.下载安装 yum install -y mysql-server2.服务开启 service mysqld start3.服务随开机启动 chkconfig mysqld on4.进入mysql mysql exit5.安装连接 yum in

1.centOS安装Mysql

上个星期研究了一个星期的Mysql,从今天起把学到的东西整理一下. ---------------------------------------------- mysql安装本人亲试过两种安装方式,一种rpm方式,一种绿色方式安装,个人感觉rpm方式最方便 1.rpm方式 1)需要的软件包:(5.5为例,https://dev.mysql.com/downloads/mysql/5.5.html#downloads) MySQL-client-5.5.48-1.linux2.6.i386.rp

centos安装mysql数据库

a.镜像自带安装 1.查看系统mysql rpm -qa | grep mysql 2.强制卸载历史版本 rpm -e --nodeps mysql 3.查看yum源下提供的msyql yum list | grep mysql 4.执行安装 yum install -y mysql-server mysql mysql-devel rpm -qi mysql-server 5.启动 service mysqld start 6.修改为开机自启动 chkconfig --list | grep

centos 安装 mysql

安装mysql server #yum install mysql-server 安装mysql client #yum install mysql 设置服务自动启动 #chkconfig --levels 235 mysqld on 设置mysql root密码 #/usr/bin/mysqladmin -u root password '******' 启动.停止.重启 一.启动方式 1.使用 service 启动:service mysqld start 2.使用 mysqld 脚本启动:

linix (Centos) 安装 mysql

Linux(centos)安装mysql 数据库 卸载原先数据库 1.  查询系统有没有安装数据库 rpm -qa | grep mysql 2.卸载原先的数据库 rpm -e mysql // 普通删除模式  rpm -e --nodeps mysql // 强力删除模式,如果使用上面命令删除时,提示有依赖的其它文件,则用该命令可以对其进行强力删除 使用yum 安装数据库 1.查询yum提供的数据库版本 yum list | grep mysql 2.安装数据库 yum install  -y

Centos 安装mysql

CentOs中mysql的安装与配置[转] 在linux中安装数据库首选MySQL,Mysql数据库的第一个版本就是发行在Linux系统上,其他选择还可以有postgreSQL,oracle等 在Linux上安装mysql数据库,我们可以去其官网上下载mysql数据库的rpm包,http://dev.mysql.com/downloads/mysql/5.6.html#downloads,大家可以根据自己的操作系统去下载对应的数据库文件 这里我是通过yum来进行mysql数据库的安装的,通过这种

Centos安装mysql.rpm

从centos7版本开始,为了保持更好的开源度,系统最小化版本的默认数据库变为mariadb,但为了实验需要,决定还是安装mysql(毕竟两者的存储引擎是有区别的,尽管mariadb能很好的兼容mysql),下面介绍如何安装. 首先需要安装的mysql版本是6.0,下载地址:http://mysql.mirrors.pair.com/Downloads/MySQL-6.0/(采用rpm包安装方式). 1.卸载mariadb 刚开始安装时由于没有卸载系统自带的mariadb,安装mysql-ser

CentOS 安装MySQL(rpm)提示错误Header V3 DSA/SHA1 Signature

提示错误:Header V3 DSA/SHA1 Signature, key ID 5072e1f5: NOKEY error: Failed dependencies 错误原因:这是由于yum安装了旧版本的GPG keys造成的 解决办法:后面加上--force --nodeps 原文: 摘要: CentOS安装rpm安装MySQL时爆出警告: 警告:mysql-server-5.5.46-1.linux2.6.x86_64.rpm: 头V3 DSA/SHA1 Signature, 密钥 ID