mysql主從配置實現一主一從讀寫分離

来源:https://www.cnblogs.com/ritchy/archive/2019/06/20/11060578.html
-Advertisement-
Play Games

主從介紹Mysql主從又叫Replication、AB複製。簡單講就是A與B兩台機器做主從後,在A上寫數據,另外一臺B也會跟著寫數據,實現數據實時同步mysql主從是基於binlog,主上需開啟binlog才能進行主從主從過程大概有3個步驟主將更改操作記錄到binlog里從將主的binlog事件(s ...


主從介紹
Mysql主從又叫Replication、AB複製。簡單講就是A與B兩台機器做主從後,在A上寫數據,另外一臺B也會跟著寫數據,實現數據實時同步
mysql主從是基於binlog,主上需開啟binlog才能進行主從
主從過程大概有3個步驟
主將更改操作記錄到binlog里
從將主的binlog事件(sql語句) 同步本機上並記錄在relaylog里
從根據relaylog裡面的sql語句按順序執行

mysql主從是非同步複製過程
master開啟bin-log功能,日誌文件用於記錄資料庫的讀寫增刪
需要開啟3個線程,master IO線程,slave開啟 IO線程 SQL線程,
Slave 通過IO線程連接master,並且請求某個bin-log,position之後的內容。
MASTER伺服器收到slave IO線程發來的日誌請求信息,io線程去將bin-log內容,position返回給slave IO線程。
slave伺服器收到bin-log日誌內容,將bin-log日誌內容寫入relay-log中繼日誌,創建一個master.info的文件,該文件記錄了master ip 用戶名 密碼 master bin-log名稱,bin-log position。
slave端開啟SQL線程,實時監控relay-log日誌內容是否有更新,解析文件中的SQL語句,在slave資料庫中去執行。

主從作用
實時災備,用於故障切換
讀寫分離,提供查詢服務
備份,避免影響業務

主從形式
一主一從
一主多從(擴展系統讀取的性能,因為讀是在從庫讀取的)
多主一從(5.7之後開始)
主主複製
聯機複製

主從複製步驟
主庫將所有的寫操作記錄在binlog日誌中,並生成log dump線程,將binlog日誌傳給從庫的I/O線程
從庫生成兩個線程,一個是I/O線程,另一個是SQL線程
I/O線程去請求主庫的binlog日誌,並將binlog日誌中的文件寫入relay log(中繼日誌)中
SQL線程會讀取relay loy中的內容,並解析成具體的操作,來實現主從的操作一致,達到最終數據一致的目的

主從複製配置步驟
確保從資料庫與主資料庫里的數據一致
在主資料庫里創建一個同步賬戶授權給從資料庫使用
配合主資料庫(修改配置文件)
配置從資料庫(修改配置文件)

需求
搭建兩台MYSQL伺服器,一臺作為主伺服器,一臺作為從伺服器,主伺服器進行寫操作,從伺服器進行讀操作

環境說明
資料庫角色 IP 應用與系統 有無數據
主資料庫 192.168.4.219 centos7 mysql-5.7 有
從資料庫 192.168.4.218 centos7 mysql-5.7 無

在兩台伺服器上都按裝mysql
環境準備
關閉防火牆以SELINUX
service iptables stop
sed -ri 's/(SELINUX=).*/\1disabled/g' /etc/selinux/config
setenforce 0

安裝mysql
安裝依賴包
yum -y install ncurses-devel openssl-devel openssl cmake mariadb-devel

創建用戶和組
[root@yanyinglai ~]# groupadd -r -g 306 mysql
[root@yanyinglai ~]# useradd -M -s /sbin/nologin -g 306 -u 306 mysql

下載二進位格式的mysql軟體包
--[root@yanyinglai ~]# cd /usr/src/
--[root@yanyinglai src]#wget https://downloads.mysql.com/archives/get/file/mysql-5.7.22-linux-glibc2.12-x86_64.tar.gz
已下載
[root@localhost ~]# cd soft/
[root@localhost soft]# ls -ltrh
total 1.2G
-rw-r--r--. 1 root root 566M Jun 4 18:12 mysql-8.0.11-linux-glibc2.12-i686.tar.gz
-rw-r--r-- 1 root root 614M Jun 13 16:54 mysql-5.7.22-linux-glibc2.12-x86_64.tar.gz

解壓軟體至/usr/local/
[root@localhost soft]# tar xf mysql-5.7.22-linux-glibc2.12-x86_64.tar.gz -C /usr/local/
[root@localhost soft]# ls /usr/local/
bin config config1 config2 etc games include jdk1.6 lib lib64 libexec mysql-5.7.22-linux-glibc2.12-x86_64 python3 sbin share src tomcat
[root@localhost soft]# cd /usr/local/

[root@localhost local]# ln -sv mysql-5.7.22-linux-glibc2.12-x86_64/ mysql
`mysql' -> `mysql-5.7.22-linux-glibc2.12-x86_64/'
[root@localhost local]# ll


修改目錄/usr/locaal/mysql的屬主屬組
[root@localhost local]# chown -R mysql.mysql /usr/local/mysql
[root@localhost local]# ll /usr/local/mysql -d
lrwxrwxrwx 1 mysql mysql 36 Jun 20 17:17 /usr/local/mysql -> mysql-5.7.22-linux-glibc2.12-x86_64/

添加環境變數

[root@localhost local]# ls /usr/local/mysql
bin COPYING docs include lib man README share support-files
[root@localhost local]# cd
[root@localhost local]# echo 'export PATH=/usr/local/mysql/bin:$PATH' > /etc/profile.d/mysql.sh
[root@localhost local]# . /etc/profile.d/mysql.sh
[root@localhost local]# echo $PATH
/usr/local/mysql/bin:/usr/local/jdk1.6/bin:/usr/local/ssl/bin:/usr/local/mysql/bin:/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin

建立數據存放目錄
[root@localhost local]# cd /usr/local/mysql
[root@localhost mysql]# mkdir -p /opt/data
[root@localhost mysql]# chown -R mysql.mysql /opt/data/
[root@localhost mysql]# ll /opt/
total 0
drwxrwxr-x 7 mysql mysql 4096 Jun 18 15:25 data

初始化資料庫
[root@yanyinglai mysql]# /usr/local/mysql/bin/mysqld --initialize --user=mysql --datadir=/opt/data/
//這個命令的最後會生成一個臨時密碼,後面修改初始密碼需要

主庫218
2019-06-20T09:21:02.883424Z 1 [Note] A temporary password is generated for root@localhost: qij(Gork)2Nt

備庫219
2019-06-20T09:44:49.512519Z 1 [Note] A temporary password is generated for root@localhost: TU6w?erhvg7*

配置mysql
[root@localhost mysql]# ln -sv /usr/local/mysql/include/ /usr/local/include/mysql
`/usr/local/include/mysql' -> `/usr/local/mysql/include/'
[root@localhost mysql]# echo '/usr/local/mysql/lib' > /etc/ld.so.conf.d/mysql.conf
[root@yanyinglai ~]# ldconfig -v

生成配置文件,下麵是顯示結果
[root@localhost mysql]# cat > /etc/my.cnf <<EOF
> [mysqld]
> basedir = /usr/local/mysql
> datadir = /opt/data
> socket = /tmp/mysql.sock
> port = 3306
> pid-file = /opt/data/mysql.pid
> user = mysql
> skip-name-resolve
> EOF

執行下麵的
cat > /etc/my.cnf <<EOF
[mysqld]
basedir = /usr/local/mysql
datadir = /opt/data
socket = /tmp/mysql.sock
port = 3306
pid-file = /opt/data/mysql.pid
user = mysql
skip-name-resolve
EOF

配置服務啟動腳本
[root@localhost mysql]# cp -a /usr/local/mysql/support-files/mysql.server /etc/init.d/mysqld
[root@localhost mysql]# sed -ri 's#^(basedir=).*#\1/usr/local/mysql#g' /etc/init.d/mysqld
[root@localhost mysql]# sed -ri 's#^(datadir=).*#\1/opt/data#g' /etc/init.d/mysqld

啟動mysql
[root@localhost mysql]# service mysqld start
Starting MySQL.Logging to '/opt/data/localhost.localdomain.err'.
SUCCESS!

[root@localhost mysql]# ps -ef|grep mysql
root 4897 1 0 22:38 pts/2 00:00:00 /bin/sh /usr/local/mysql/bin/mysqld_safe --datadir=/opt/data --pid-file=/opt/data/mysql.pid
mysql 5075 4897 6 22:38 pts/2 00:00:01 /usr/local/mysql/bin/mysqld --basedir=/usr/local/mysql --datadir=/opt/data --plugin-dir=/usr/local/mysql/lib/plugin --user=mysql --log-error=yanyinglai.err --pid-file=/opt/data/mysql.pid --socket=/tmp/mysql.sock --port=3306
root 5109 4668 0 22:38 pts/2 00:00:00 grep --color=auto mysql
[root@localhost mysql]# ss -antl
State Recv-Q Send-Q Local Address:Port Peer Address:Port
LISTEN 0 128 *:22 *:*
LISTEN 0 100 127.0.0.1:25 *:*
LISTEN 0 128 :::22 :::*
LISTEN 0 100 ::1:25 :::*
LISTEN 0 80 :::3306

修改密碼
使用臨時密碼修改
[root@yanyinglai ~]# mysql -uroot -p
mysql> set password = password('123456');
mysql> quit

mysql主從配置
確保從資料庫與主資料庫的數據一樣先在主資料庫創建所需要同步的庫和表
[root@localhost mysql]# mysql -uroot -p123456
mysql> create database yan;
Query OK, 1 row affected (0.00 sec)

mysql> create database lisi;
Query OK, 1 row affected (0.00 sec)

mysql> create database wangwu;
Query OK, 1 row affected (0.00 sec)

mysql> use yan;
Database changed
mysql> create table tom (id int not null,name varchar(100)not null ,age tinyint);
Query OK, 0 rows affected (11.83 sec)

mysql> insert tom (id,name,age) values(1,'zhangshan',20),(2,'wangwu',7),(3,'lisi',23);
Query OK, 3 rows affected (0.07 sec)
Records: 3 Duplicates: 0 Warnings: 0

mysql> select * from tom;

備份主庫
備份主庫時需要另開一個終端,給資料庫上讀鎖,避免在備份期間有其他人在寫入導致數據同步的不一致
[root@localhost mysql]# mysql -uroot -p123456

mysql> flush tables with read lock;
Query OK, 0 rows affected (0.01 sec)

//此鎖表的終端必須在備份完成以後才能退出(退出鎖表失效)
備份主庫並將備份文件傳送到從庫
[root@localhost ~]# mysqldump -uroot -p123456 --all-databases > /opt/all-20190620.sql
mysqldump: [Warning] Using a password on the command line interface can be insecure.
[root@localhost ~]# scp /opt/all-20190620.sql [email protected]:/opt/
解除主庫的鎖表狀態,直接退出互動式界面即可

mysql> quit
Bye

【同上步驟安裝從庫】

在從庫上恢復主庫的備份並查看是否與主庫的數據保持一致
安裝配置同上
[root@rdtest mysql]# mysql -uroot -p123456 < /opt/all-20190620.sql
mysql: [Warning] Using a password on the command line interface can be insecure.
[root@yanyinglai ~]# mysql -uroot -p123456
mysql> show databases;
mysql> use yan;
mysql> select * from tom;

主從配置

在主資料庫創建一個同步賬戶授權給從數據使用 IP對應為slave的
[root@localhost ~]# mysql -uroot -p123456
mysql> create user 'repl'@'192.168.4.219' identified by '123456';
Query OK, 0 rows affected (5.50 sec)

mysql> grant replication slave on *.* to 'repl'@'192.168.4.219';
Query OK, 0 rows affected (0.04 sec)

mysql> flush privileges;
Query OK, 0 rows affected (0.09 sec)

配置主資料庫編輯配置文件
[root@localhost ~]# vi /etc/my.cnf
//添加以下內容
[mysqld]
basedir = /usr/local/mysql
datadir = /opt/data
socket = /tmp/mysql.sock
port = 3306
pid-file = /opt/data/mysql.pid
user = mysql
skip-name-resolve

//添加以下內容
//啟用binlog日誌
log-bin=mysql-bin
//主資料庫伺服器唯一標識符 主的必須必從大
server-id=1
log-error=/opt/data/mysql.log

重啟mysql服務
[root@yanyinglai ~]# service mysqld restart
Shutting down MySQL..... SUCCESS!
Starting MySQL.Logging to '/opt/data/mysql.log'.
............................... SUCCESS!
[root@yanyinglai ~]# ss -antl
State Recv-Q Send-Q Local Address:Port Peer Address:Port
LISTEN 0 128 *:22 *:*
LISTEN 0 100 127.0.0.1:25 *:*
LISTEN 0 128 :::22 :::*
LISTEN 0 100 ::1:25 :::*
LISTEN 0 80 :::3306 :::*

[root@localhost ~]# mysql -uroot -p123456
查看主庫的狀態
mysql> show master status;
+------------------+----------+--------------+------------------+-------------------+
| File | Position | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set |
+------------------+----------+--------------+------------------+-------------------+
| mysql-bin.000003 | 154 | | | |
+------------------+----------+--------------+------------------+-------------------+
1 row in set (0.00 sec)

配置從資料庫
編輯配置文件

添加以下內容:
server-id=2 //設置從庫的唯一標識符 從的必須比主小
relay-log=mysql-relay-bin //啟用中繼日誌relay log
error-log=/opt/data/mysql.log

[root@rdtest mysql]# vi /etc/my.cnf
[mysqld]
basedir = /usr/local/mysql
datadir = /opt/data
socket = /tmp/mysql.sock
port = 3306
pid-file = /opt/data/mysql.pid
user = mysql
skip-name-resolve

server-id=2
relay-log=mysql-relay-bin
log-error=/opt/data/mysql.log

重啟從庫的mysql服務
[root@rdtest mysql]# service mysqld restart
Shutting down MySQL.. SUCCESS!
Starting MySQL.Logging to '/opt/data/mysql.log'.
SUCCESS!
[root@rdtest mysql]# ss -antl
State Recv-Q Send-Q Local Address:Port Peer Address:Port
LISTEN 0 128 :::22 :::*
LISTEN 0 128 *:22 *:*
LISTEN 0 100 ::1:25 :::*
LISTEN 0 100 127.0.0.1:25 *:*
LISTEN 0 10 *:5672 *:*
LISTEN 0 80 :::3306 :::*
[root@rdtest mysql]#

配置並啟動主從複製
主節點的二進位文件一定要是二進位列表中的最後一個二進位文件
mysql> change master to
-> master_host='192.168.4.218', //主庫IP
-> master_user='repl',//複製用戶
-> master_password='123456',//用戶密碼
-> master_log_file='mysql-bin.000003',
-> master_log_pos=154;
Query OK, 0 rows affected, 2 warnings (0.00 sec)

change master to
master_host='192.168.4.218',
master_user='repl',
master_password='123456',
master_log_file='mysql-bin.000003',
master_log_pos=154;

查看從伺服器狀態

mysql> show slave status\G;
Slave_IO_Running: Yes //此處必須是yes
Slave_SQL_Running: Yes //此處必須是yes

ERROR:
No query specified
測試驗證在主伺服器的yan庫的tom表插入數據:
mysql> use yan;
mysql> select * from tom;
mysql> insert tom(id,name,age) value (4,"zgy",18);
Query OK, 1 row affected (0.14 sec)
mysql> select * from tom;

insert tom(id,name,age) value (5,"zgy",16);
update tom set name='yyyyy' where age=18;
delete from tom where age=18;

在從資料庫查看是否數據同步
mysql> use yan;
mysql> select * from tom;

關註Slave_IO_State,Slave_IO_Running,Slave_SQL_Running狀態
若都為yes狀態時確認同步配置完成

【檢查】
查看主庫二進位日誌是否開啟
mysql> show global variables like '%log%';
| log_bin | ON |

查看主節點二進位日誌列表
mysql> show master logs;
查看主節點的server id
mysql> show global variables like '%server%';
| server_id | 1 |

mysql> show global variables like '%log%';
| log_bin | OFF |

| relay_log | mysql-relay-bin |
| relay_log_basename | /opt/data/mysql-relay-bin |
| relay_log_index | /opt/data/mysql-relay-bin.index |

mysql> show global variables like '%server%';

| server_id | 2 |

從庫
開啟中繼日誌
添加:relay-log=relay-log
添加:relay-log-index=relay-log.index
添加:server-id=2
添加:innodb_file_per_table=ON
添加:skip_name_resolve=ON

查看進程
mysql> show processlist;

查看表結構
mysql> show create table tom \G
*************************** 1. row ***************************
Table: tom
Create Table: CREATE TABLE `tom` (
`id` int(11) NOT NULL,
`name` varchar(100) NOT NULL,
`age` tinyint(4) DEFAULT NULL
) ENGINE=InnoDB DEFAULT CHARSET=latin1
1 row in set (0.00 sec)

執行計劃
mysql> explain select * from tom;
+----+-------------+-------+------------+------+---------------+------+---------+------+------+----------+-------+
| id | select_type | table | partitions | type | possible_keys | key | key_len | ref | rows | filtered | Extra |
+----+-------------+-------+------------+------+---------------+------+---------+------+------+----------+-------+
| 1 | SIMPLE | tom | NULL | ALL | NULL | NULL | NULL | NULL | 5 | 100.00 | NULL |
+----+-------------+-------+------------+------+---------------+------+---------+------+------+----------+-------+
1 row in set, 1 warning (0.00 sec)

限制從伺服器為只讀
從伺服器 read_only = ON,但是此限制對擁有SUPER許可權的用戶均無效。
阻止所有用戶
mysq>FLUSH TABLES WITH READ LOCK;

【從庫只讀】
需要保證master-slave主從同步的salve庫,如果要設置為只讀狀態,可以限定普通用戶進行數據修改的操作,但不會限定具有super許可權的用戶
set global read_only=1;

查詢有哪些資料庫
show databases;
查詢某資料庫有哪些表
use mysql
show tables;
獲取binlog文件列表
show binary logs;
只查看第一個binlog文件的內容
show binlog events;
查看指定binlog文件的內容
show binlog events in 'mysql-bin.000001';

初始化異常處理
[root@rdtest mysql]# ./bin/mysqld --initialize --user=mysql --datadir=/opt/data/
./bin/mysqld: error while loading shared libraries: libaio.so.1: cannot open shared object file: No such file or directory
安裝一下
[root@rdtest mysql]# yum install -y libaio
[root@rdtest mysql]# ./bin/mysqld --initialize --user=mysql --datadir=/opt/data/
2019-06-13T09:28:47.897255Z 1 [Note] A temporary password is generated for root@localhost: 4TB,9Q+&j3he

Error: Protected multilib versions: libstdc++-4.4.7-23.el6.i686 != libstdc++-4.4.7-17.el6.x86_64
You could try using --skip-broken to work around the problem
You could try running: rpm -Va --nofiles --nodigest
安裝下麵的包
yum --skip-broken update
yum clean all
yum install libstdc++.so.6


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • [toc] 命令 1.文件的上傳下載 2.從外網下載文件wget | wget | 文件下載 | | | | | O | 指定地址下載,更改名稱 | | T | 超時時間 | | q | 安靜下載(關閉wget輸出) | | spider | 網路爬蟲 | 3.curl文件下載 4.查找命令whic ...
  • 添加sysfs介面 使用device_create_file/ device_create_group 添加static DEVICE_ATTR(fm1288, 0666, fm1288_show, fm1288_store); ...
  • 準備工作下載百度網盤: https://www.baidu.com/s?wd=%E7%99%BE%E5%BA%A6%E7%BD%91%E7%9B%98&rsv_spt=1&rsv_iqid=0xfc68ab6200065efa&issp=1&f=8&rsv_bp=1&rsv_idx=2&ie=utf ...
  • 想通過VPN上網,因為各種免費或收費的VPN工具不是不穩定就是怕不靠譜,所以打算自己搭一個玩玩。以下是搭建的大致過程: 因為只是做個實驗環境,所以申請了一個騰訊雲的15天免費伺服器,以下是相關信息: 系統:CentOS 6.5 64位 公網IP:139.155.96.23 內網IP:172.27.0 ...
  • 創建一個socket,使用函數socket() socket(套接字)實質上提供了進程通信的端點,進程通信之前,雙方首先必須建立各自的一個端點,否則沒有辦法通信。通過socket將IP地址和埠綁定之後,客戶端就可以和伺服器通信了 #include<sys/socket.h> int socket( ...
  • 有時候動態sql需要進行變數的賦值,這個時候就需要調用系統的存儲過程sp_executesql了。使用中還是有些註意事項,代碼如下: 執行結果如下: ...
  • 一、查詢表空間常規語句 1.查詢表空間使用情況 SELECT Upper(F.TABLESPACE_NAME) "表空間名", D.TOT_GROOTTE_MB "表空間大小(M)", D.TOT_GROOTTE_MB - F.TOTAL_BYTES "已使用空間(M)", To_char(Roun ...
  • MySQL表操作 存儲引擎:存儲數據的方式 Innodb存儲引擎: Myisam存儲: Memory存儲引擎: 查看當前的預設存儲引擎: 表介紹 表就相當於文件,表中的一條記錄就相當於文件的一行內容,不同的是,表中的一條記錄有對應的標題,稱為表的欄位 還記得我們之前寫過的‘員工信息表作業’麽?存儲這 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...