真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯網站制作重慶分公司

mysql執(zhí)行間隔怎么寫,mysql日期間隔

如何設置mysql主從同步時間間隔 linux

linux下配置mysql主從同步的步驟

創(chuàng)新互聯建站是一家從事企業(yè)網站建設、成都網站設計、做網站、成都外貿網站建設公司、行業(yè)門戶網站建設、網頁設計制作的專業(yè)網站建設公司,擁有經驗豐富的網站建設工程師和網頁設計人員,具備各種規(guī)模與類型網站建設的實力,在網站建設領域樹立了自己獨特的設計風格。自公司成立以來曾獨立設計制作的站點上1000家。

一、主機環(huán)境

主機:

master操作系統(tǒng):rhel6.0

IP:172.16.0.100

MySQL版本:5.1.47

從機:

slave操作系統(tǒng):rhel6.0

IP:172.16.0.200

MySQL版本:5.1.47

二、創(chuàng)建數據庫

分別登錄master機和slave機的mysql:mysql –u root –p

創(chuàng)建數據庫:create database repl;

三、master機和slave機的相關配置

1、修改master機器中mysql配置文件my.cnf,該文件在/etc目錄下

在[mysqld]配置段添加如下字段

server-id=1

log-bin=mysql-bin

binlog-do-db=repl //需要同步的數據庫,如果沒有本行,即表示同步所有的數據庫

binlog-ignore-db=mysql //被忽略的數據庫

在master機上為slave機添加一同步帳號

grant replication slave on *.* to 'replication'@'172.16.0.200' identified by '123456';

重啟master機的mysql服務:service mysqld restart

用show master status 命令看日志情況

mysqlshow master status;

+-----------------+------------+-------------------+-----------------------+

| File | Position | Binlog_Do_DB | Binlog_Ignore_DB |

+-----------------+------------+-------------------+-----------------------+

| log.000003 | 98 | repl | mysql |

+-----------------+------------+-------------------+-----------------------+

1 row in set (0.00 sec)

2、修改slave機中mysql配置文件

同樣在[mysqld]字段下添加如下內容

server-id=2

master-host=172.16.0.100

master-user=repl

master-password=123456

master-port=3306

master-connect-retry=60

replicate-do-db=repl //同步的數據庫,不寫本行 表示 同步所有數據庫

然后重啟slave機的mysql

在slave機中進入mysql

mysqlstart slave;

mysqlshow slave status\G;

如果Slave_IO_Running、Slave_SQL_Running狀態(tài)為Yes則表明設置成功。

這時 再執(zhí)行show slave status\G

顯示如下:

*************************** 1. row ***************************

Slave_IO_State: Waiting for master to send event

Master_Host: 192.168.1.222

Master_User: repl

Master_Port: 3306

Connect_Retry: 60

Master_Log_File: log.000003

Read_Master_Log_Pos: 98

Relay_Log_File: mysqld-relay-bin.000002

Relay_Log_Pos: 229

Relay_Master_Log_File: log.000003

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: 98

Relay_Log_Space: 229

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

1 row in set (0.00 sec)

Slave_IO_Running: Yes Slave_SQL_Running: Yes

信息中如上兩行都為Yes,說明配置成功。

五、測試主從服務器是否能同步

在主服務器上面新建一個表,必須在repl數據下

mysql use repl

Database changed

mysql create table test(id int,name char(10));

Query OK, 0 rows affected (0.00 sec)

mysql insert into test values(1,'zaq');

Query OK, 1 row affected (0.00 sec)

mysql insert into test values(1,'xsw');

Query OK, 1 row affected (0.00 sec)

mysql select * from test;

+------+------+

| id | name |

+-------+------+

| 1 | zaq |

| 1 | xsw |

+-------+------+

2 rows in set (0.00 sec)

在從服務器查看是否同步過來

mysql use repl;

Database changed

mysql select * from test;

+------+------+

| id | name |

+------+------+

| 1 | zaq |

| 1 | xsw |

+------+------+

2 rows in set (0.00 sec)

說明已經配置成功。

四、出現的問題

1. 當在執(zhí)行start slave這條命令時,系統(tǒng)提示

ERROR 1200 (HY000): The server is not configured as slave; fix in config file or with CHANGE MASTER TO,

執(zhí)行show slave status;又提示Empty set (0.00 sec)

原因:slave已經默認開啟,要先關閉再開啟

執(zhí)行 slave stop;

再執(zhí)行

change master to master_host='172.16.0.200',master_user='repl',master_password='123456', master_log_file='log.000003' ,master_log_pos=98;

2、出現錯誤提示 :Slave_IO_Running:NO

mysql的error日志中信息:

Slave I/O: error connecting to master 'replication@172.16.0.100:3306' - retry-time: 60 retries: 86400, Error_code: 1045

解決方法

1.在主mysql中創(chuàng)建slave遠程連接訪問時候的登錄密碼一定要設置對。

2.停止slave上的mysqld服務,從服務器上刪除掉所有的二進制日志文件,包括一個數據目錄下的master.info文件和hostname-relay-bin開頭的文件,然后啟動slave上的mysqld服務。

master.info::記錄了Mysql主服務器上的日志文件和記錄位置、連接的密碼。

3.slave上Slave_SQL_Running: No ,提示某個表定義不正確

解決方法:

清空drop掉master和slave上的已經存在所有表,然后從master庫上導入新的數據即可。

mysql中每隔一段時間自動執(zhí)行一次sql語句

mysql要實現定時執(zhí)行sql語句就要用到Event

具體操作如下:

先看看看event 事件是否開啟

show variables like '%sche%';

如沒開啟,則開啟。需要數據庫超級權限

set global event_scheduler =1;

創(chuàng)建存儲過程 update_a (注:就是你要執(zhí)行的sql語句)

mysql create procedure update_a() update a set a.y_avg=(select avg(b.youhao) from b where a.a_id=b.a_id);

創(chuàng)建一個定時任務:event e_updateA

mysql create event if not exists e_updateA

- on schedule every 60 second ---設置60秒執(zhí)行一次

- on schedule at date_add(now(),interval 1 minute) ---在一分鐘后執(zhí)行

- on completion preserve

- do call update_a(); ---執(zhí)行update_a()存儲過程

創(chuàng)建Event之后,sql語句就定時執(zhí)行一次。

關閉事件任務

mysql alter event e_updateA ON

- COMPLETION PRESERVE DISABLE;

開啟事件任務

mysql alter event e_updateA ON

- COMPLETION PRESERVE ENABLE;

如還有問題再聯系我

mysql查詢時間間隔

select count(*) from sometable where datetimecolumn=UNIX_TIMESTAMP('2010-03-01 00:00:00') and

datetimecolumnUNIX_TIMESTAMP('2010-03-02 00:00:00'),也可以在調用程序中先轉換為UNIX時間再傳入MySql,總之這種方式有利于快速查詢時間段,不過顯示時間則需要再反轉一次。


網頁名稱:mysql執(zhí)行間隔怎么寫,mysql日期間隔
網頁地址:http://weahome.cn/article/hoppip.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部