mysql维护 运维_MySQL运维之--日常维护操作
MySQL運(yùn)維之--日常維護(hù)操作
http://blog.csdn.net/guoyjoe/article/details/46697825
一、Linux內(nèi)核和發(fā)行版本?uname -a
cat /etc/issue
二、glibc的版本
/lib/libc.so.6 ? ?---沒有man函數(shù)據(jù)的動(dòng)態(tài)鏈接庫(kù)
三、MySQL的版本
MySQL二進(jìn)制分發(fā)版的文件名格式為:mysql-VERSION-OS.tar.gz
例如:Linux-Generic(glibc 2.5) (x86,64bit),Compressed TAR Archive(mysql-5.6.16-linux-glibc2.5-x86_64.tar.gz)
1、下載
http://dev.mysql.com/downloads/mysql/
2、查rpm包裝在什么目錄下
rpm -qpl MySQL-server-5.6.23-1.el6.i686.rpm ?|more
rpm -qpl MySQL-client-5.6.23-1.el6.x86_64.rpm |more
3、更改rpm安裝路徑
rpm --help
rpm --prefix ?--relocate
rpmbuild spec binary rpm
yum install
四、rpm安裝
rpm -ivh xxx.rmp
rpm -pql xxx.rmp
MySQL ?實(shí)例安裝和啟動(dòng)
1. 安裝
mysql_install_db --defaults-file=/root/data/mysql3306/my.cnf --basedir=/usr/ --datadir=/root/data/mysql3306/data
2. 啟動(dòng)
mysqld_safe --defaults-file=/root/data/mysql3306/my.cnf &
3. 登錄
mysql -h127.0.0.1 -uroot -P3306 -p
五、安裝演示:
1.關(guān)閉mysql
ps -ef |grep mysqld
kill ?3397 3801
2.安裝
cat init3306
sh init3306.sh
3.啟動(dòng)
cat start3306.sh
sh start3306.sh
注意:mysql_install_db(通過安裝rpm包產(chǎn)生mysql_install_db),有如下命令查看:
rpm -pql MySQL-server-5.5.42-1.linux2.6.i386.rpm |grep install
which ?mysql_install_db
4.看日志
tail ?-100f /root/data/mysql3306/log/alert.log
發(fā)生數(shù)據(jù)字典不存在,就會(huì)自動(dòng)創(chuàng)建。。。。
5.查看進(jìn)程
ps -ef |grep mysqld
mysqld_safe是mysqld的父進(jìn)程
6.登錄
sh ?my3306.sh ?--mysql -h127.0.0.1 -uroot --P3306
六、腳本:
1.---安裝mysql: init3306.sh
rm -rf /root/data/mysql3306/data/*
rm -rf /root/log/mysql3306/iblog/*
rm -rf /root/log/mysql3306/binlog/*
chmod -R 777 /root/data/mysql3306/data/
chmod -R 777 /root/log/mysql3306/iblog/
chmod -R 777 /root/log/mysql3306/binlog/
chmod 755 /root/data/mysql3306/my.cnf
mysql_install_db --defaults-file=/root/data/mysql3306/my.cnf --basedir=/usr/ --datadir=/root/data/mysql3306/data
chmod -R 777 /root/data/mysql/3306/data/
chmod -R 777 /root/log/mysql3306/iblog/
chmod -R 777 /root/log/mysql3306/binlog/
2.--啟動(dòng)mysql: start336.sh
mysqld_safe --defaults-file=/root/data/mysql3306/my.cnf &
3.--登錄mysql: my3306.sh
mysql -h127.0.0.1 -uroot -P3306 -p
------研究下
cd /root/data/mysql3306/data/mysql
cd /root/data/mysql3306/data/performance_schema ?--性能相關(guān)的
cd /root/data/mysql3306/data/test ? ?---測(cè)試庫(kù)
cd /root/log/mysql3306/iblog/ ? ? ? ?---innodb自己的數(shù)據(jù)和日志
------了解my.cnf(多實(shí)例用端口來取分)
vi /root/data/mysql3306/my.cnf
[client]
port=3306
socket=/root/data/mysql3306/run/mysql.sock
[mysql]
port=3306
promprt=\\u@\\d \\r:\\m:\\s>
[mysqld]
default-storage-engine=INNODB
character-set-server=iatin1
explicit_defaults_for_timestamp=true
#dir
innodb_log_group_home_dir=/root/log/mysql3306/iblog
innodb_data_home_dir=/root/log/mysql3306/iblog
basedir=/usr
datadir=/root/data/mysql3306/data
tmpdir=/root/data/mysql3306/tmp
slave_load_tmpdir=/root/data/mysql3306/tmp
log-error=/root/data/mysql3306/log/alert.log
slow_query_log_file=/root/data/mysql3306/log/slow.log
relay_log_info_file=/root/log/mysql3306/binlog/relay-log.info
master-info-file=/root/log/mysql3306/binlog/master.info
socket=/root/data/mysql3306/run/mysql.sock
log-bin=/root/log/mysql3306/binlog/binlog
relay-log=/root/log/mysql3306/binlog/relaylog
innodb_force_recovery=0
七、操作mysql
1、登錄mysql:
本地: ?mysql -u$usrename -p$password
遠(yuǎn)程: ?mysql -u$username -p$passwrod -h$ip
多實(shí)例:mysql -u$username -p$passwrod -P$port
2、用戶操用
(1)創(chuàng)建用戶
方法一:
insert into mysql.user(user,host,password) values(‘mytest‘,‘localhost‘,password(‘1234‘));
flush privilege;
方法二:create user mystest@‘%‘ identified by ‘1234‘;
(2)用戶授權(quán)
單純的授權(quán)
grant all privileges on *.* to mytest@localhost;
grant insert,update,delete,select on *.* to mytest@localhost;
授權(quán)并創(chuàng)建用戶
grant all privileges on *.* to mytest@localhost identified by ‘1234‘;--創(chuàng)建用戶并刷緩存,
(等同于:insert into mysql.user ,flush privilege)
grant all privileges on *.* to mytest@localhost; ? --對(duì)象權(quán)限
grant super on *.* to mytest@‘%‘; ? --系統(tǒng)權(quán)限 ?(supert相當(dāng)于oracle中的dba權(quán)限)
3、實(shí)操
show databases; ? --查看所有的數(shù)據(jù)庫(kù)
use mysql; ? ? ? ?--切到mysql數(shù)據(jù)庫(kù)
use tables; ? ? ? --在mysql庫(kù)的tables
select user,host,password from mysql.user; ?----查mysql的所有用戶,這個(gè)是由mysql_install_db創(chuàng)建的
grant all privilege on *.* to test_1@‘%‘; --all代表(select update,delete,alter admin,super_acl),第一個(gè)*用戶,第二個(gè)*對(duì)象,%所有的主機(jī)
mysql -h127.0.0.1 -utest_1 ? ?----用grant創(chuàng)建的用戶登錄mysql
select user(); ? ---當(dāng)前是什么用戶
create database jianfeng; ---創(chuàng)建數(shù)據(jù)庫(kù)(mysql中的數(shù)據(jù)庫(kù)類似于oracle中的schema
create table user(id int) engine=innodb ? ---創(chuàng)建表;
grant select on jianfeng.user to test_1@‘%‘; ?---jianfeng.user表的查詢授權(quán)給test_1用戶
insert into mysql.user(user,host,password) values(‘test_2‘,‘%‘,password(‘1234‘)); --用這種方法創(chuàng)建test_2用戶,有個(gè)問題權(quán)限沒有
flush privileges; ?---把mysql.user表的用戶權(quán)限重新刷到內(nèi)存中
show master status\G;
change master to xxx;
show processlist; ? ---查看當(dāng)前用戶的連接,線程形式(類似oracle中的v$session)
4、drop table處理
rename table test_1 to test;(可以快速切回來rename table test to test_1;)
備份mysqldump:mysqldump -h127.0.0.1 -uroot mydb gyj_t1 >/tmp/gyj_t1.sql
drop table test;
5、自增主鍵(最好是自己定義主鍵,系統(tǒng)默認(rèn)的是全局的增量)
create table test (id int primary key auto_increment,name varchar(100)) engine=innodb;
show create table test\G;
create index test_name_idx on test(name);
show create table test\G;
insert into test(name) values(‘test‘);
commit;
select * from test;
6、alter table處理 ?--會(huì)動(dòng)原來的數(shù)據(jù),需要拷貝數(shù)據(jù)
alter table test add coll int;
7、執(zhí)行計(jì)劃
select * from test where id=1\G;
explain select * from test where id=1;
create index test_id_coll_idx on test(id,coll);
explain select * from test where id=1;
create index test_col_name on test(coll,name);
explain select * from test where coll>10 and name=‘xx‘;
show create table test\G;
alter table test drop index test_name_idx;
explain select * from test where coll>10 and name>‘xx‘;
8、數(shù)據(jù)導(dǎo)出
(1)用dump導(dǎo)出數(shù)據(jù)
mysqldump -h127.0.0.1 -uroot mydb gyj_t1 >/tmp/xx.sql
drop table test;
source /tmp/xx.sql ? ?--導(dǎo)入數(shù)據(jù)
(2)用select導(dǎo)出數(shù)據(jù)
select * from test into outfile ‘/tmp/yy.sql‘;
9、數(shù)據(jù)遷移
(1)停機(jī)方式
mysqldump/loadata
(2)不停機(jī)方式
物理上:搭備庫(kù)(可以級(jí)聯(lián)5.5-->5.6,向下兼容的)
把主庫(kù)read only,備庫(kù)就能把主庫(kù)轉(zhuǎn)過來的binlog消化完,再把備庫(kù)切為主
show variables like ‘%read%‘;
set global read_only=on;
insert into test(name) values(‘xx‘); ?--插不進(jìn)的,不能用root用戶
(3)不同平臺(tái)小表:oracle--->mysql
腳本:synfull.pl
(4)不同平臺(tái)的一個(gè)大表遷多:增量遷移
a.把數(shù)據(jù)的全量遷過去
b.把遷的過程中產(chǎn)生的日志傳過去
c.apply增量
d.鎖表切切換
(5)增量
a.Oracle:物化視圖
b.MySQL:trigger
create trigger tri_test
before insert,delete,update
insert test_log value(type,id);
end;
/
insert into test values(1,‘xxx‘);
test_log value(‘insert‘,‘1‘);
lock table test;
應(yīng)用切換
10、binlog
reset master; ? --會(huì)把當(dāng)前的binlog清掉
show binlog events;
create table x1(id int);
show binlog events;
insert into x1 values(1);
commit;
show binlog events;
類似于: mysqlbinlog -vvv binlog.00001 > /tmp/binlog.log
vi /tmp/binlog.log
WAL: write ahead log,日志優(yōu)先寫
11、歸檔
flush logs;
show master status;
write ahead log. recover backup, duriably. undo acid mvcc
12、參數(shù)和統(tǒng)計(jì)信息
show variables; ?----參數(shù)
show variables like ‘%bin%‘;
show status; ? ? ?----統(tǒng)計(jì)信息
show global status like‘%insert%‘;
insert into test(name) values(‘xxxxx‘);
show variables like ‘%default%‘;
set global default_storage_engine=myisam; ? ---不影響當(dāng)前會(huì)話的操作,影響新建立的連接
set session default_storage_engine=myisam; ?---影響當(dāng)前會(huì)話的操作
---連接池
max_connect
min_connect
max_idle
time_out
disconnect --釋放
版權(quán)聲明:本文為博主原創(chuàng)文章,未經(jīng)博主允許不得轉(zhuǎn)載。
MySQL運(yùn)維之--日常維護(hù)操作
標(biāo)簽:mysql運(yùn)維之--日常維護(hù)操作
本條技術(shù)文章來源于互聯(lián)網(wǎng),如果無意侵犯您的權(quán)益請(qǐng)點(diǎn)擊此處反饋版權(quán)投訴
本文系統(tǒng)來源:http://blog.csdn.net/guoyjoe/article/details/46697825
總結(jié)
以上是生活随笔為你收集整理的mysql维护 运维_MySQL运维之--日常维护操作的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: mysql r和n的区别_mysql数据
- 下一篇: 查询过去一个月有付款mysql_MySQ