MySQL營運之--日常維護操作,mysql--日常維護

來源:互聯網
上載者:User

MySQL營運之--日常維護操作,mysql--日常維護


轉載請註明出處:http://blog.csdn.net/guoyjoe/article/details/46697825


一、Linux核心和發行版本

 uname -a
 cat /etc/issue
 
 二、glibc的版本
   /lib/libc.so.6    ---沒有man函資料的動態連結程式庫
   
三、MySQL的版本
   MySQL二進位分發版的檔案名稱格式為: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  執行個體安裝和啟動
1. 安裝
mysql_install_db --defaults-file=/root/data/mysql3306/my.cnf --basedir=/usr/ --datadir=/root/data/mysql3306/data
2. 啟動
mysqld_safe --defaults-file=/root/data/mysql3306/my.cnf &
3. 登入
mysql -h127.0.0.1 -uroot -P3306 -p




五、安裝示範:
 
1.關閉mysql
   ps -ef |grep mysqld
   kill  3397 3801
   
2.安裝
cat init3306
sh init3306.sh


3.啟動
cat start3306.sh
sh start3306.sh
   
  注意:mysql_install_db(通過安裝rpm包產生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
  發生資料字典不存在,就會自動建立。。。。


5.查看進程
ps -ef |grep mysqld
    mysqld_safe是mysqld的父進程 



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.--啟動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  --效能相關的
cd /root/data/mysql3306/data/test    ---測試庫
cd /root/log/mysql3306/iblog/        ---innodb自己的資料和日誌




------瞭解my.cnf(多執行個體用連接埠來取分)
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
  遠程:  mysql -u$username -p$passwrod -h$ip
  多執行個體:mysql -u$username -p$passwrod -P$port
  
2、使用者操用
(1)建立使用者
  方法一:
   insert into mysql.user(user,host,password) values('mytest','localhost',password('1234'));
   flush privilege;
  方法二:create user mystest@'%' identified by '1234';
    
(2)使用者授權
 單純的授權
   grant all privileges on *.* to mytest@localhost; 
   grant insert,update,delete,select on *.* to mytest@localhost;
 授權並建立使用者  
   grant all privileges on *.* to mytest@localhost identified by '1234';--建立使用者並刷緩衝,
                                                                     (等同於:insert into mysql.user ,flush privilege)
   grant all privileges on *.* to mytest@localhost;   --對象許可權
   grant super on *.* to mytest@'%';   --系統許可權  (supert相當於oracle中的dba許可權)
   
  
  
3、實操
show databases;   --查看所有的資料庫
use mysql;        --切到mysql資料庫
use tables;       --在mysql庫的tables
select user,host,password from mysql.user;  ----查mysql的所有使用者,這個是由mysql_install_db建立的
grant all privilege on *.* to test_1@'%'; --all代表(select update,delete,alter admin,super_acl),第一個*使用者,第二個*對象,%所有的主機 
mysql -h127.0.0.1 -utest_1    ----用grant建立的使用者登入mysql
select user();   ---當前是什麼使用者
create database jianfeng; ---建立資料庫(mysql中的資料庫類似於oracle中的schema
create table user(id int) engine=innodb   ---建立表;
grant select on jianfeng.user to test_1@'%';  ---jianfeng.user表的查詢授權給test_1使用者
insert into mysql.user(user,host,password) values('test_2','%',password('1234')); --用這種方法建立test_2使用者,有個問題許可權沒有
flush privileges;  ---把mysql.user表的使用者權限重新刷到記憶體中
show master status\G; 
change master to xxx; 
show processlist;   ---查看目前使用者的串連,線程形式(類似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、自增主鍵(最好是自己定義主鍵,系統預設的是全域的增量)
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處理  --會動原來的資料,需要拷貝資料
alter table test add coll int;


7、執行計畫
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、資料匯出
(1)用dump匯出資料
mysqldump -h127.0.0.1 -uroot mydb gyj_t1 >/tmp/xx.sql
drop table test;
source /tmp/xx.sql    --匯入資料


(2)用select匯出資料
select * from test into outfile '/tmp/yy.sql';


9、資料移轉
(1)停機方式
   mysqldump/loadata
(2)不停機方式
  物理上:搭備庫(可以級聯5.5-->5.6,向下相容的)
     把主庫read only,備庫就能把主庫轉過來的binlog消化完,再把備庫切為主
     show variables like '%read%';
     set global read_only=on;
     insert into test(name) values('xx');  --插不進的,不能用root使用者
(3)不同平台小表:oracle--->mysql
      指令碼:synfull.pl
      
(4)不同平台的一個大表遷多:增量遷移
    a.把資料的全量遷過去
    b.把遷的過程中產生的日誌傳過去
    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;
   應用程式切換
   
10、binlog
   reset master;   --會把當前的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,日誌優先寫


11、歸檔   
  flush logs;
  show master status;
  
 
 write ahead log. recover backup, duriably. undo acid mvcc
 
12、參數和統計資訊
show variables;  ----參數
show variables like '%bin%';
show status;      ----統計資訊
show global status like'%insert%';
insert into test(name) values('xxxxx');


show variables like '%default%';
set global default_storage_engine=myisam;   ---不影響當前會話的操作,影響建立立的串連
set session default_storage_engine=myisam;  ---影響當前會話的操作


---串連池
max_connect
min_connect
max_idle
time_out

disconnect --釋放



著作權聲明:本文為博主原創文章,未經博主允許不得轉載。

相關文章

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.