Centos 7 mysql 安装使用记
某次把美团云1G 1核 centos 7 装到死机,明白了源码编译安装mysql是个大坑,遂绕路到其他大道。
- 安装命令
wget http://dev.mysql.com/get/mysql-community-release-el7-5.noarch.rpm rpm -ivh mysql-community-release-el7-.noarch.rpm yum install mysql-community-server
- 配置mysql
service mysqld restart mysql -u root
mysql> set password for 'root'@'localhost' =password('vm_52.102');
[root@localhost liuhui]# service mysqld restart
Redirecting to /bin/systemctl restart mysqld.service
[root@localhost liuhui]# mysql -u root
Welcome to the MySQL monitor. Commands end with ; or \g.
Your MySQL connection id is
Server version: 5.6. MySQL Community Server (GPL) Copyright (c) , , 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> set password for 'root'@'localhost' =password('password');
Query OK, rows affected (0.00 sec)
正常进程
[root@localhost liuhui]# ps aux|grep mysqld
mysql 0.0 0.0 ? Ss : : /bin/sh /usr/bin/mysqld_safe
mysql 0.1 6.3 ? Sl : : /usr/sbin/mysqld --basedir=/usr --datadir=/var/lib/mysql --plugin-dir=/usr/lib64/mysql/plugin --log-error=/var/log/mysqld.log --pid-file=/var/run/mysqld/mysqld.pid --socket=/var/lib/mysql/mysql.sock
===============================================
【安装过程中的错误】
1、软件包依赖 mariadb组件
错误:软件包:akonadi-mysql-1.9.-.el7.x86_64 (@anaconda)
需要:mariadb-server
正在删除: :mariadb-server-5.5.-.el7.centos.x86_64 (@anaconda)
mariadb-server = :5.5.-.el7.centos
取代,由: mysql-community-server-5.6.-.el7.x86_64 (mysql56-community)
未找到
更新,由: :mariadb-server-5.5.-.el7_2.x86_64 (updates)
mariadb-server = :5.5.-.el7_2
可用: :mariadb-server-5.5.-.el7_2.x86_64 (updates)
mariadb-server = :5.5.-.el7_2
您可以尝试添加 --skip-broken 选项来解决该问题
您可以尝试执行:rpm -Va --nofiles --nodigest
解决:移除对 mariadb-libs的依赖
yum -y remove mariadb-libs
2、在阿里云机器上遇到 libc.so.6(GLIBC_2.17)依赖问题
Error: Package: mysql-community-client-5.6.35-2.el7.x86_64 (mysql56-community)
Requires: libc.so.6(GLIBC_2.17)(64bit)
Error: Package: mysql-community-libs-5.6.35-2.el7.x86_64 (mysql56-community)
Requires: libc.so.6(GLIBC_2.17)(64bit)
Error: Package: 2:postfix-2.6.6-6.el6_7.1.x86_64 (base)
Requires: libmysqlclient.so.16(libmysqlclient_16)(64bit)
Removing: mysql-libs-5.1.73-3.el6_5.x86_64 (@updates)
libmysqlclient.so.16(libmysqlclient_16)(64bit)
Obsoleted By: mysql-community-libs-5.6.35-2.el7.x86_64 (mysql56-community)
Not found
Updated By: mysql-libs-5.1.73-8.el6_8.x86_64 (updates)
libmysqlclient.so.16(libmysqlclient_16)(64bit)
Available: mysql-libs-5.1.73-7.el6.x86_64 (base)
libmysqlclient.so.16(libmysqlclient_16)(64bit)
Error: Package: mysql-community-server-5.6.35-2.el7.x86_64 (mysql56-community)
Requires: libstdc++.so.6(GLIBCXX_3.4.15)(64bit)
Error: Package: 2:postfix-2.6.6-6.el6_7.1.x86_64 (base)
Requires: libmysqlclient.so.16()(64bit)
Removing: mysql-libs-5.1.73-3.el6_5.x86_64 (@updates)
libmysqlclient.so.16()(64bit)
Obsoleted By: mysql-community-libs-5.6.35-2.el7.x86_64 (mysql56-community)
Not found
Updated By: mysql-libs-5.1.73-8.el6_8.x86_64 (updates)
libmysqlclient.so.16()(64bit)
Available: mysql-libs-5.1.73-7.el6.x86_64 (base)
libmysqlclient.so.16()(64bit)
Error: Package: mysql-community-server-5.6.35-2.el7.x86_64 (mysql56-community)
Requires: libc.so.6(GLIBC_2.17)(64bit)
Error: Package: mysql-community-server-5.6.35-2.el7.x86_64 (mysql56-community)
Requires: systemd
You could try using --skip-broken to work around the problem
You could try running: rpm -Va --nofiles --nodigest
【mysql的启动和停止】
# ) 启动 ---官方推荐使用 mysqld_safe 进程启动,遇到mysqld进程停止,mysqld_safe自动重新启动 nohup /bin/sh /usr/bin/mysqld_safe & #) 停止 使用 shutdown停止mysql mysqladmin -uroot -p shutdown;
===============================================
【mysql启动错误】
检查mysql的错误日志发现 是配置文件问题
cat /var/log/mysqld.log |grep ERROR 2016-- :: [ERROR] /usr/sbin/mysqld: unknown variable 'default-character-set=utf8'
-- :: [ERROR] Aborting
vim /etc/my.cnf #default-character-set=utf8
character_set_server=utf8
把字符集编码的设置 更改一下,default 改为character_set
===============================================
【mysql运维演练】
1、修改mysql的默认数据库路径,转移到指定目录~/mysql_data下
【command list】
()停服务 copy文件
mysqladmin -uroot -p shutdown; cd /var/lib
cp -a -r /var/lib/mysql /home/mysql_data/ chown mysql:mysql /home/mysql_data/mysql
chmod /home/mysql_data/mysql/mysql.sock chmod a+x /home/mysql_data/
chmod mysql:mysql a+x /home/mysql_data/
# 启动mysql
/bin/sh /usr/bin/mysqld_safe ()修改3个配置
cp /etc/my.cnf /etc/my.cnfbak
cp /usr/bin/mysqld_safe /usr/bin/mysqld_safebak vim /etc/my.cnf
datadir=/home/mysql_data/mysql
socket=/home/mysql_data/mysql/mysql.sock vim /usr/bin/mysqld_safe
datadir=/home/mysql_data/mysql ()建立链接
ln -s /home/mysql_data/mysql/mysql.sock /var/lib/mysql/mysql.sock
再启动mysql
/bin/sh /usr/bin/mysqld_safe
2、部分配置参数的意义整理
interactive_timeout= #服务器关闭交互式连接前等待活动的秒数,单位秒,默认8小时,28800秒。避免闲置连接过多。
wait_timeout= #服务器关闭非交互连接之前等待活动的秒数与iteractive_timeout一起设置客户端超时时间。
#只有 wait_timeout 会真正起到超时限制的作用
interactive_timeout和wait_timeout在连接空闲阶段(sleep)起作用 max_allowed_packet=16M #消息缓冲区包的最大大小 net_read_timeout= #在终止读之前,从一个连接获得数据而等待的时间秒数;
当服务正在从客户端读取数据时,net_read_timeout控制何时超时
net_write_timeout= # 在终止写之前,等待多少秒把block写到连接;
当服务正在写数据到客户端时,net_write_timeout控制何时超时
net_read_timeout和net_write_timeout:则是在连接繁忙阶段(query)起作用 max_connect_errors=10000 #主机在连接被中断(网络,或者程序意外中断)等,都会增加 connect_errors的计数值,
当超过了阈值就只能被 blocked,如果连接成功,计数值又会被初始为0;如果出现错误,还是老老实实的 flush hosts吧
max_connections=1000 #mysql 最大连接数
connect_timeout= # 在获取连接阶段(authenticate)起作用
bulk_insert_buffer_size = 256M # 批量insert脚本大小设置,有 blob大字段要设置大一些,
2、查询结果导出到文件
1) 直接命令行执行
mysql -h 127.0.0.1 -uroot -p -Ne "use test; select * from test limit 100;" > /tmp/outdata.txt 2) 命令行调用sql文件执行 vim run_out.sql
use test; select * from test limit 100;
mysql -uroot -p -N < run_out.sql > /tmp/outdata.txt
3、mysql 数据导入
#【source 和 load data infile 命令,进入mysql】 mysql > use test
mysql > set names utf8
mysql > source /home/mysql_data/test.sql; #load data ,注意 local参数。 以下生成测试数据 并导入测试表
python -c "for i in range(1,1+1000000): print(i)">100w.txt
mysql > create table tmp_series(id int,primary key(id));
mysql > load data local infile '/home/test/100w.txt' replace into table tmp_series; --------------------------------
[不加local参数,报错]
ERROR (HY000): The MySQL server is running with the --secure-file-priv option so it cannot execute this statement
4、Innodb 和 myisam 存储引擎的差异
Innodb 需要事务处理或是外键,update更快些,严格保持数据一致性时更适合;
select count from tables, innodb实时去扫描表计数,慢
auto_increment自动增长计数器仅被存储在主内存中,而不是存在磁盘上
MyISAM 需要全文索引,大批的inserts 语句在MyISAM下会快一些,count更快,快速写入数据场景更适合;
3个构成文件,.frm文件存储表定义,.MYD 数据文件,.MYI 索引文件
select count from tables, myisam直接读系统结果表,很快
更好和更快的auto_increment处理;
5、数据库表的一些修复方法
# shell 命令行下执行
mysqlcheck -uroot -p database test table -c test # myisamchk修复myisam存储引擎的错误表,对innodb无效,必须在mysql服务停止后进行,-O参数设置各项参数内存大小; myisamchk -r tablename myisamchk –safe-recover tbl_name
myisamchk -O sort=16M -O key=16M -O read=1M -O write=1M ... # innnodb的表修复,可通过修改表存储引擎 导数据,再修改回来等方式
具体参考 【Innodb 表修复】http://www.cnblogs.com/zhoujinyi/archive/2013/05/10/3070667.html
【master-slave主从复制】
【配置数据库的主从复制,此方案是 服务器对服务器,所有库的任何变更都会同步到从库上,新建库,新建任何表等】
主从服务需要确保mysql版本一致;log-bin设成二进制日志;server-id主从分别设成唯一值, #vi /etc/my.cnf
[mysqld]
log-bin=mysql-bin //[必须]启用二进制日志
server-id=222 //[必须]服务器唯一ID,默认是1,一般取IP最后一段,主服务器, server-id=223 //从服务器 分别重启两个mysql server。 【master服务器】
mysql > GRANT REPLICATION SLAVE ON *.* to 'mysync'@'%' identified by 'q123456';
mysql > show master status
+------------------+----------+--------------+------------------+-------------------+
| File | Position | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set |
+------------------+----------+--------------+------------------+-------------------+
| mysql-bin.000001 | 320 | | | |
+------------------+----------+--------------+------------------+-------------------+ 【slave库】
mysql > change master to master_host='192.168.52.101',master_user='mysync',master_password='q123456',
master_log_file='mysql-bin.000001',master_log_pos=320;
【slave库查看主从复制状态】
mysql> show slave status\G
*************************** 1. row ***************************
Slave_IO_State: Waiting for master to send event
Master_Host: 192.168.52.101
Master_User: mysync
Master_Port: 3306
Connect_Retry: 60
Master_Log_File: mysql-bin.000001
Read_Master_Log_Pos: 961
Relay_Log_File: mysqld-relay-bin.000002
Relay_Log_Pos: 924
Relay_Master_Log_File: mysql-bin.000001
Slave_IO_Running: Yes
Slave_SQL_Running: Yes
Replicate_Do_DB:
Replicate_Ignore_DB:
Replicate_Do_Table:
Replicate_Ignore_Table:
Replicate_Wild_Do_Table:
Replicate_Wild_Ignore_Table:
Last_Errno: 0
Last_Error:
Skip_Counter: 0
Exec_Master_Log_Pos: 961
Relay_Log_Space: 1098
Until_Condition: None
Until_Log_File:
Until_Log_Pos: 0
Master_SSL_Allowed: No
Master_SSL_CA_File:
Master_SSL_CA_Path:
Master_SSL_Cert:
Master_SSL_Cipher:
Master_SSL_Key:
Seconds_Behind_Master: 0
Master_SSL_Verify_Server_Cert: No
Last_IO_Errno: 0
Last_IO_Error:
Last_SQL_Errno: 0
Last_SQL_Error:
Replicate_Ignore_Server_Ids:
Master_Server_Id: 222
Master_UUID: 6be51420-bb89-11e6-99c1-000c29d16f0c
Master_Info_File: /var/lib/mysql/master.info
SQL_Delay: 0
SQL_Remaining_Delay: NULL
Slave_SQL_Running_State: Slave has read all relay log; waiting for the slave I/O thread to update it
Master_Retry_Count: 86400
Master_Bind:
Last_IO_Error_Timestamp:
Last_SQL_Error_Timestamp:
Master_SSL_Crl:
Master_SSL_Crlpath:
Retrieved_Gtid_Set:
Executed_Gtid_Set:
Auto_Position: 0
1 row in set (0.00 sec)
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
【参考资料馆】
监控mysql主从复制状态的shell脚本 http://blog.formyz.org/?paged=6
centos6.5下安装mysql http://www.linuxidc.com/Linux/2015-01/111413.htm
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
Centos 7 mysql 安装使用记的更多相关文章
- CentOS下Mysql安装教程
CentOS下Mysql安装教程 本人学习Linux时使用的是CentOs5.5版本,在该环境中,Mysql的安装方法有很多种,下面我只讲我这次成功了的方法,作为一个记录,供大家参考,同时给自己做一个 ...
- [Centos 7]MYSQL 安装及登录问题
1. Centos 7 上安装mysql 8 rpm -qa |grep -i mysql //看自己系统有没有装mysql wget https://dev.mysql.com/get/mysql8 ...
- Linux下Java开发环境搭建—CentOS下Mysql安装教程
本人学习Linux时使用的是CentOs5.5版本,在该环境中,Mysql的安装方法有很多种,下面我只讲我这次成功了的方法,作为一个记录,供大家参考,同时给自己做一个笔记. MySQL下载 1.进入网 ...
- Centos 下mysql安装配置
一.编译安装MySQL前的准备工作 安装编译源码所需的工具和库 yum install gcc gcc-c++ ncurses-devel perl 安装cmake,从http://www.cmake ...
- CentOS下mysql安装和配置
1.卸载原有mysql [root@iZ25ka6ra32Z /]# rpm -qa | grep mysql 查看该操作系统上是否已经安装了mysql数据库.有的话,我们就通过 rpm -e 命令 ...
- CentOS下MySQL安装失败,报socket '/tmp/mysql.sock错误解决方法
1.在centos里安装mysql数据库后,登录时提示‘/tmp/mysql.sock’ 第一种解决办法:采用ln链接方式进行处理 ln -s /var/lib/mysql/mysql.sock /t ...
- Centos 下 mysql 安装过程
1. 检查系统自带的Mysql,并卸载自带的版本 [root@iZ2366ycl7sZ config]# yum list installed |grep mysql mysql.x86_64 5.1 ...
- Linux - centos 7 mysql安装
安装 CentOS Linux release 7.1.1503 (Core)下载地址链接:https://pan.baidu.com/s/1c2rWsbm 密码:5nrt #yum -y insta ...
- CentOS下Mysql安装调试
一.安装 yum安装:yum install -y mysql-server mysql mysql-devel 设置自启动:chkconfig mysqld on 启动MySQL:service ...
随机推荐
- Python学习笔记(四十七)SMTP发送邮件
摘抄自:https://www.liaoxuefeng.com/wiki/0014316089557264a6b348958f449949df42a6d3a2e542c000/001432005226 ...
- dotnet core 实践——日志组件Serilog
前几天把基于quartz.net的部分项目代码移植到了dotnet core ,但是没增加日志功能,原因是没找到合适的组件. 今天终于找到了Serilog: https://github.com/s ...
- HashSet的特性介绍
HashSet除了在元素的存储上是无序的以外,还是不能够存储重复的元素. HashSet如何判断元素是否重复呢?是根据元素继承的两个方法来判断,hashCode和equals,当存储元素时,首先判断要 ...
- HDFS默认副本数为什么是3
转载自: https://www.cnblogs.com/bugchecker/p/why_three_replications_for_HDFS_in_engineer.html HDFS采用一种称 ...
- 【BZOJ】3495: PA2010 Riddle 2-SAT算法
[题意]有n个城镇被分成了k个郡,有m条连接城镇的无向边.要求给每个郡选择一个城镇作为首都,满足每条边至少有一个端点是首都.n,m,k<=10^6. [算法]2-SAT,前后缀优化建图 [题解] ...
- sylk文件
症状:excel表出现提示:sylk文件...导致excel表不可读取 原因:文件内容有“ ID ” 字段,估计是固定的识别“ID”或“ID_XXXX” 修改方法:将ID中的任意字母换成小写即可 转载 ...
- 【洛谷 P4016】 负载平衡问题(费用流)
题目链接 环形均分纸牌,既然是网络流23题的那就用网络流做把. 套路拆点. 供需平衡. 源点向大于平均数的点的入点连流量为这个数减去平均数的差,费用为0的边,表示需要移走这么多. 小于平均数的点的出点 ...
- kendo method:destroy 解决有些在kendo.all.js 的js 库里报错问题
首先,不得不承认,kendo UI 是个不错的东西,特别对于一个前端开发到行不足的程序猿来说.而在我们使用过程中貌似还是会遇到各种奇怪的问题.比如我们会经常用到对一些控件进行重赋值. destroy ...
- 四. Jmeter--JDBC 请求
一, SQLserver 1.下载 JDBC Driver (sqljdbc_6.0.8112.100_enu.exe) https://www.microsoft.com/en-us/downlo ...
- elk系列3之通过json格式采集Nginx日志【转】
转自 elk系列3之通过json格式采集Nginx日志 - 温柔易淡 - 博客园http://www.cnblogs.com/liaojiafa/p/6158245.html preface 公司采用 ...