MySQL安装部署及调优
MySQL安装
二进制安装 - mysql-5.5.49
mkdir /home/oldboy/tools -p
cd /home/oldboy/tools/
rz
#mysql-5.5.49-linux2.6-x86_64.tar.gz
tar -xf mysql-5.5.49-linux2.6-x86_64.tar.gz
mv mysql-5.5.49-linux2.6-x86_64 /application/mysql-5.5.49
useradd -s /sbin/nologin mysql -M
ln -s /application/mysql-5.5.49/ /application/mysql
cd /application/mysql
/bin/cp support-files/my-small.cnf /etc/my.cnf
chown -R mysql.mysql /application/mysql/
/application/mysql/scripts/mysql_install_db --basedir=/application/mysql --datadir=/application/mysql/data/ --user=mysql
cp support-files/mysql.server /etc/init.d/mysqld
chmod +x /etc/init.d/mysqld
sed -i 's#/usr/local/mysql#/application/mysql#g' /application/mysql/bin/mysqld_safe /etc/init.d/mysqld
/etc/init.d/mysqld start
echo 'export PATH=/application/mysql/bin:$PATH' >>/etc/profile
source /etc/profile
mysqladmin -u root password '123456'
lsof -i:3306
MySQL基本操作
shell界面下命令:
启动:/etc/init.d/mysqld start
停止:/etc/init.d/mysqld stop
重启:/etc/init.d/mysqld restart
登陆:mysql -u账号 -p密码
设置密码:mysqladmin -u root password '新密码'
mysql界面下命令:
清理无用的MySQL用户及库
select user,host from mysql.user
drop user "root@::1";
删除无用数据库
drop database test;
show database test;
查看当前所有的数据库
show databases;
查看当前的登陆用户
select user();
MySQL优化
mysql相关命令加入全局路径的配置
方法一:
echo 'export PATH=/application/mysql/bin:$PATH' >>/etc/profile
source /etc/profile
方法二:
ln -s /application/mysql/bin/* /usr/local/sbin/
多实例
mkdir /data/{3306,3307}/data -p
多实例配置文件模板 : ls -l support-files/my*.cnf
编辑多实例配置文件 : vim /data/3306/my.cnf
vim /data/3307my.cnf
创建启动文件 : vim /data/3306/mysql
vim /data/3307mysql
启动多实例:
mysqld_safe--defaults-file=/data/3306/my.cnf 2>&1 >/dev/null &
mysqld_safe--defaults-file=/data/3307/my.cnf 2>&1 >/dev/null &
停止多实例:
mysqladmin -u root -p密码 -S /data/3306/mysql.sock shutdown
mysqladmin -u root -p密码 -S /data/3307/mysql.sock shutdown
初始化mysql多实例数据库文件
cd /application/mysql/scripts
./mysql_install_db --basedir=/application/mysql --datadir=/data/3306/data --user=mysql
./mysql_install_db --basedir=/application/mysql --datadir=/data/3307/data --user=mysql
启动\登陆\重启多实例多实例数据库
启动
/data/3306/mysql start
/data/3307/mysql start
停止
/data/3306/mysql stop
/data/3307/mysql stop
重启
/data/3306/mysql stop
/data/3307/mysql stop
开机自启动
echo "#mysql multi instance" >>/etc/rc.local
echo "/data/3306/mysql start" >>/etc/rc.local
echo "/data/3307/mysql start" >>/etc/rc.local
登陆多实例数据库
mysql -S /data/3306/mysql.sock
设置/修改多实例数据库密码
mysqladmin -u root -S /data/3306/mysql.sock password '密码'
mysql -uroot -p密码 -S /data/3306/mysql.sock
实例的密码存放在/data/3306/mysql文件中,需修改权限为700,防止密码被其他用户看到
find /data -type f -name "mysql" -exec chmod 700 {} \;
修改实例密码:sed -i '13 s#旧密码#新密码#g' /data/3306/mysql /data/3307/mysql
禁止使用pkill、kill -9、killall -9等命令强制杀死数据库,这会引起数据库无法启动等故障的发生
MySQL主从复制
MySQL的主从复制并不是数据库磁盘上的文件直接拷贝,而是Master上开启binlog记录功能,Slave从Master端获取binlog日志,然后再在Slave上以相同顺序执行获取的binlog日志中所记录的各种SQL记录。
开启binlog
[mysqld]
log-bin = /data/3006/mysql-bin
实战 主从同步 <3306为主,3307为从>
开启Master的binlog功能
vim /data/3306/my.cnf
[mysqld]
server-id = 1
log-bin = /data/3006/mysql-bin
/data/3306/mysql restart
登陆数据库检查参数是否生效
egrep "server-id|log-bin" /data/3306/my.cnf
mysql -uroot -p'密码' -S /data/3306/mysql.sock
show variables like 'server_id';
show variables like 'log_bin';
在主库上建立用于主从复制的账号
mysql -uroot -p'密码' -S /data/3306/mysql.sock
grant replication slave on *.* to 'rep'@'10.0.0.%' identified by '密码';
flush privileges;
检查创建的rep复制账号
select user,host from mysql.user;
select user,host from mysql.user where user='rep';
MySQL权限说明:
实现对主数据库锁表只读
锁表只读,然后mysqldump出数据库,然后再解锁
flush table with read lock;
show variables like '%timeout%';
显示信息记录在案
show master status;
或mysql -u root -p '密码' -S /data/3306/mysql.sock -e "show master status"
锁表后,一定要新开ssh窗口,再导出数据库所有数据
mkdir /server/backup -p
mysqldump -uroot -p密码 -S /data/3306/mysql.sock --events -A -B|gzip >/server/backup/mysql_bak.$(date +%F).sql.gz
从库编辑my.cnf文件,添加server-id(id号不能和主一样),注释掉binlog功能,重启从数据库
将导出的数据库发送到从库上导入(可以用scp、rsyn)
gzip -d mysql_bak.2017-01-01.sql.gz
mysql -uroot -p'密码' -S /data/3307/mysql.sock < mysql_back.2017-01-01.sql
从库连接主库配置信息
mysql -uroot -p'密码' -S /data/3307/mysql.sock << EOF
CHANGE MASTER TO
MASTER_HOST='10.0.0.7'
MASTER_PORT='3306'
MASTER_USER='rep'
MASTER_PASSWORD='密码'
MASTER_LOG_FILE='mysql-bin.000008'
MASTER_LOG_POS=342
启动从库同步开关
mysql -uroot -p密码 -S /data/3307/mysql.sock -e "start slave;"
mysql -uroot -p密码 -S /data/3307/mysql.sock -e "show slave status;"
测试
主库上创建个账号
mysql -uroot -p密码 -S /data/3306/mysql.sock -e "create database testtest;"
从库上查看
mysql -uroot -p密码 -S /data/3307/mysql.sock -e "show databases like 'testtest';"
MySQL安装部署及调优的更多相关文章
- Mysql安装与配置调优
一.安装apt-get install mysql-server 需要设置账号密码 apt-get isntall mysql-client apt-get libmysqlclient-dev2.s ...
- Ubuntu14.04 Django Mysql安装部署全过程
Ubuntu14.04 Django Mysql安装部署全过程 一.简要步骤.(阿里云Ubuntu14.04) Python安装 Django Mysql的安装与配置 记录一下我的部署过程,也方便 ...
- mysql监控、性能调优及三范式理解
原文:mysql监控.性能调优及三范式理解 1监控 工具:sp on mysql sp系列可监控各种数据库 2调优 2.1 DB层操作与调优 2.1.1.开启慢查询 在My.cnf文件中添加如 ...
- 【叶问】 MySQL常用的sql调优手段或工具有哪些
MySQL常用的sql调优手段或工具有哪些1.根据执行计划优化 通常使用desc或explain,另外可以添加format=json来输出更详细的json格式的执行计划,主要注意点如下: ...
- MySQL性能诊断与调优 转
http://www.cnblogs.com/preftest/ http://www.highperfmysql.com/ BOOK LAMP 系统性能调优,第 3 部分: MySQL 服务 ...
- MySQL插入数据性能调优
插入数据性能调优总结: 1.SQL插入语句调优 2.如果是InnoDB引擎的话,尝试开启事务,批量提交 3.调整MySQl数据库配置 参考: 百度空间 - MySQL插入数据性能调优 CSDN ...
- MySQL安装部署
MySQL安装部署 使用自动化脚本
- MySQL性能诊断与调优
LAMP 系统性能调优,第 3 部分: MySQL 服务器调优http://www.ibm.com/developerworks/cn/linux/l-tune-lamp-3.html LoadRun ...
- 2-MySQL DBA笔记-MySQL安装部署和入门
第2章 MySQL安装部署和入门 第1章介绍了MySQL的一些基础知识,本章将为读者介绍MySQL的部署.安装及一些常用命令和参数的设置.2.1 如何选择MySQL版本 在选择MySQL的版本时,要根 ...
随机推荐
- zabbix_server.log大量提示cannot send list of active checks to "IP": host [HostName] not found
zabbix server 日志大量提示上图信息 原因是 zabbix_agent.conf配置文件中配置的HostName与zabbix的web界面配置的不同导致的 zabbix_agent.con ...
- 【前端】jQuery选择器$()的实现原理
今天三七互娱技术面试的时候面试官问了我这个问题,当时一脸懵逼,于是好好总结一下. 当我们使用jquery选择器的时候,$(s).回默认去执行jquery内部封装好的一个init的构造函数每次申明一个j ...
- 从0开始 数据结构 AC自动机 hdu 2222
参考博客 失配指针原理 使当前字符失配时跳转到另一段从root开始每一个字符都与当前已匹配字符段某一个后缀完全相同且长度最大的位置继续匹配,如同KMP算法一样,AC自动机在匹配时如果当前字符串匹配失败 ...
- 2017 ACM-ICPC 亚洲区(南宁赛区)网络赛 B题
2017-09-24 19:16:38 writer:pprp 题目链接:https://www.jisuanke.com/contest/877 题目如下: You are given a list ...
- 01_MySQL DQL_基础查询
DQL,Data Query Language,数据查询 # 基础查询/*语法:select 查询列表 from 表名: 特点:1.查询列表可以是:表中的字段,常量值.表达式.函数,也可以是多个组合2 ...
- No input file specified. nginx服务器报错解决
配置虚拟域名的时候报No input file specified. 仔细观察一圈也没有发现任何错误,最终,我把注意力放到 \ 上.才发现问题. 以前我都是直接copy文件路径过去 文件里面 都是使用 ...
- BZOJ3224 Tyvj 1728 普通平衡树(Treap)
本文版权归ljh2000和博客园共有,欢迎转载,但须保留此声明,并给出原文链接,谢谢合作. 本文作者:ljh2000 作者博客:http://www.cnblogs.com/ljh2000-jump/ ...
- js 冒泡型事件
- (转载)gcc & gdb & make 定义与区别
gcc & gdb & make 定义与区别 GCC 通常所说的GCC是GUN Compiler Collection的简称,除了编译程序之外,它还含其他相关工具,所以它能把易于人类使 ...
- 高性能Go并发
1.管道chan吞吐极限10,000,000,单次Put,Get耗时大约100ns/op,无论是采用单Go程,还是多Go程并发(并发数:100, 10000, 100000),耗时均没有变化,Go内核 ...