Linux-進程管理

来源:https://www.cnblogs.com/yanjieli/archive/2018/08/26/9539588.html
-Advertisement-
Play Games

關於進程 Process what is process ? 什麼是進程 process life cycle 進程的生命周期 process states 進程狀態 什麼是進程? 進程是已啟動的可執行程式的運行實例,進程有以下組成部分: • 已分配記憶體的地址空間; • 安全屬性,包括所有權憑據和特 ...


關於進程 Process

what is process ?  什麼是進程

process life cycle  進程的生命周期

process states  進程狀態

什麼是進程?

進程是已啟動的可執行程式的運行實例,進程有以下組成部分:

• 已分配記憶體的地址空間;

• 安全屬性,包括所有權憑據和特權;

• 程式代碼的一個或多個執行線程;

• 進程狀態

程式: 二進位文件,靜態 /bin/date, /usr/sbin/httpd,/usr/sbin/sshd, /usr/local/nginx/sbin/nginx 

進程: 是程式運行的過程, 動態,有生命周期及運行狀態。

進程的生命周期 

 

父進程複製自己的地址空間(fork)傳建一個新的(子)進程結構。每個新進程分配一個唯一的進程ID(PID),滿足跟蹤安全性之需,PID和父進程(PPID)是子進程環境的元素,任何進程都可以創建子進程,所有進程都是第一個系統進程的後代:

Centos5/6: init

Centos7: systemd

子進程繼承父進程的安全性身份、過去和當前的文件描述符,埠和資源特權,環境變數,以及程式代碼。隨後,子進程可能exec自己的程式代碼,通常,父進程在子進程運行期間處於睡眠(sleeping)狀態,當子進程完成時發出(exit)信號請求,在退出時,子進程已經關閉或丟棄了其資源環境,剩餘的部分稱為僵停(僵屍Zombie)。父進程在子進程退出時收到信號而被喚醒,清理剩餘的結構,然後繼續執行其自己的程式代碼。

進程狀態

在多任務處理操作系統中,每個CPU(或核心)在一個時間點上只能處理一個進程。在進程運行時,它對CPU時間和資源分配的要求會不斷變化,從而為進程分配一個狀態,它隨著環境要求而改變。

查看進程 process

瞭解如進程的:
• PID,PPID
• 當前的進程狀態
• 記憶體的分配情況
• CPU和已花費的實際時間
• 用戶UID,它決定進程的特權

靜態查看進程 ps

註:ps -aux 不同於 ps aux

[root@localhost~]# ps aux |less
USER       PID %CPU %MEM    VSZ   RSS TTY     STAT START   TIME COMMAND
root         1     0.0     0.0          2164   648 ?          Ss   08:47     0:00 init [5]  

USER:      運行進程的用戶
PID:      進程ID
%CPU:    CPU占用率
%MEM:      記憶體占用率
VSZ:      占用虛擬記憶體
RSS:       占用實際記憶體 駐留記憶體
TTY:      進程運行的終端
STAT:     進程狀態     man ps (/STATE)            
      R     運行
      S     可中斷睡眠 Sleep
      D     不可中斷睡眠
      T     停止的進程 
      Z     僵屍進程
      X     死掉的進程
      
      Ss     s進程的領導者,父進程
      S<    <優先順序較高的進程
      SN     N優先順序較低的進程
      R+      +表示是前臺的進程組
      Sl     以線程的方式運行    
START:     進程的啟動時間
TIME:     進程占用CPU的總時間
COMMAND:  進程文件,進程名

[root@localhost~]# ps aux --sort %cpu |less
[root@localhost~]# ps aux --sort -%cpu |less
[root@localhost~]# ps aux --sort rss |less
[root@localhost~]# ps aux --sort -rss |less

[alice@tianyun ~]$ sudo yum -y install httpd
[alice@tianyun ~]$ sudo systemctl start httpd
[root@localhost~]# ps auxf |grep httpd
root      9279  0.0  0.0   4264   672 pts/1    S+   14:37   0:00  \_ grep httpd
root      8310  0.0  0.1  10092  2912 ?        Ss   14:19   0:00  /usr/sbin/httpd
apache    8311  0.0  0.0  10092  2060 ?        S    14:19   0:00  \_ /usr/sbin/httpd
apache    8312  0.0  0.0  10092  2060 ?        S    14:19   0:00  \_ /usr/sbin/httpd
apache    8313  0.0  0.0  10092  2060 ?        S    14:19   0:00  \_ /usr/sbin/httpd
apache    8314  0.0  0.0  10092  2060 ?        S    14:19   0:00  \_ /usr/sbin/httpd
apache    8315  0.0  0.0  10092  2060 ?        S    14:19   0:00  \_ /usr/sbin/httpd
apache    8316  0.0  0.0  10092  2060 ?        S    14:19   0:00  \_ /usr/sbin/httpd
apache    8318  0.0  0.0  10092  2060 ?        S    14:19   0:00  \_ /usr/sbin/httpd
apache    8319  0.0  0.0  10092  2060 ?        S    14:19   0:00  \_ /usr/sbin/httpd

[root@localhost~]# ps -ef
UID        PID  PPID  C STIME TTY          TIME CMD
root         1     0  0 08:47 ?        00:00:00 init [5]  

//自定義顯示欄位
[root@localhost~]# ps axo user,pid,ppid,%mem,command
[root@localhost~]# ps axo user,pid,ppid,%mem,command |grep httpd    
root      8310     1  0.1 /usr/sbin/httpd
apache    8311  8310  0.0 /usr/sbin/httpd
apache    8312  8310  0.0 /usr/sbin/httpd
apache    8313  8310  0.0 /usr/sbin/httpd
apache    8314  8310  0.0 /usr/sbin/httpd
apache    8315  8310  0.0 /usr/sbin/httpd
apache    8316  8310  0.0 /usr/sbin/httpd
apache    8318  8310  0.0 /usr/sbin/httpd
apache    8319  8310  0.0 /usr/sbin/httpd
root      9236  6798  0.0 grep httpd
[root@localhost~]# ps axo user,pid,ppid,%mem,%cpu,command --sort -%cpu |less

//查看指定進程的PID
[yang@iZm5eiwihahzq6ds23gbf6Z ~]$ cat /run/sshd.pid 
830
[root@localhost~]# ps aux |grep sshd
root     10180  0.0  0.0   7224  1024 ?        Ss   16:00   0:00 /usr/sbin/sshd
[root@localhost~]# pgrep -l sshd
10180 sshd
[root@localhost~]# pgrep sshd
10180
[root@localhost~]# pidof sshd
10180

//查看進程樹
[root@localhost~]# pstree

動態查看進程 top

[root@localhost~]# top
[root@localhost~]# top -d 1
[root@localhost~]# top -d 1 -p 10126                        查看指定進程的動態信息
[root@localhost~]# top -d 1 -p 10126,1
[root@localhost~]# top -d 1 -u apache                    查看指定用戶的進程
[root@localhost~]# top -d 1 -b -n 2 > top.txt             將2次top信息寫入到文件

第一部分:系統整體統計信息
top - 14:15:04 up 47 min,  2 users,  load average: 0.25, 0.18, 0.12
Tasks: 235 total,   1 running, 234 sleeping,   0 stopped,   0 zombie
Cpu(s):  8.9%us,  1.0%sy,  0.0%ni, 90.1%id,  0.0%wa,  0.0%hi,  0.0%si,  0.0%st
Mem:   7944064k total,   746164k used,  7197900k free,    35724k buffers
Swap:  1048568k total,        0k used,  1048568k free,   261492k cached

load average: 0.86, 0.56, 0.78      系統最近 1分鐘,5分鐘,15分鐘平均負載

第二部分:進程信息
命令
h|?幫助
M    按記憶體的使用排序
P    按CPU使用排序
N    以PID的大小排序
R    對排序進行反轉
f    自定義顯示欄位
1    顯示所有CPU的負載

<    向前
>    向後
z    彩色
W 保存top環境設置

使用信號控制進程

 kill,killall,pkill,top

給進程發送信號

[root@localhost~]# kill -l      //列出所有支持的信號
編號 信號名
1) SIGHUP             重新載入配置
2) SIGINT             鍵盤中斷^C
3) SIGQUIT           鍵盤退出
9) SIGKILL            強制終止
15) SIGTERM          終止(正常結束),預設信號
18) SIGCONT          繼續
19) SIGSTOP          停止
20)SIGTSTP          暫停^Z

給vsftpd進程發送信號1,15

[root@localhost~]# ps aux |grep vsftpd
root      9160  0.0  0.0  52580   904 ?        Ss   21:54   0:00 /usr/sbin/vsftpd /etc/vsftpd/vsftpd.conf
[root@localhost~]# kill -1 9160            //發送重啟信號
root      9160  0.0  0.0  52580   904 ?        Ss   21:54   0:00 /usr/sbin/vsftpd /etc/vsftpd/vsftpd.conf

[root@localhost~]# kill 9160                //發送停止信號
[root@localhost~]# ps aux |grep vsftpd

//1
[yang@iZm5eiwihahzq6ds23gbf6Z ~]$ ps aux |grep crond
root       478  0.0  0.1 124144  1572 ?        Ss   09:35   0:00 /usr/sbin/crond -n
[yang@iZm5eiwihahzq6ds23gbf6Z ~]$ sudo kill -1 478
[yang@iZm5eiwihahzq6ds23gbf6Z ~]$ ps aux |grep crond
root       478  0.0  0.1 124144  1572 ?        Ss   09:35   0:00 /usr/sbin/crond -n

//15
[yang@iZm5eiwihahzq6ds23gbf6Z ~]$ sudo kill 478
[yang@iZm5eiwihahzq6ds23gbf6Z ~]$ ps aux |grep crond
[yang@iZm5eiwihahzq6ds23gbf6Z ~]$ sudo systemctl start crond 
[yang@iZm5eiwihahzq6ds23gbf6Z ~]$ ps aux |grep crond
root     22319  0.0  0.1 124140  1548 ?        Ss   14:54   0:00 /usr/sbin/crond -n

信號測試9,15

[root@localhost~]# touch file1 file2
[root@localhost~]# tty 
/dev/pts/1
[root@localhost~]# vim file1

[root@localhost~]# tty
/dev/pts/2
[root@localhost~]# vim file2

[root@localhost~]# ps aux |grep vim
root      4362  0.0  0.2  11104  2888 pts/1    S+   23:02   0:00 vim file1
root      4363  0.1  0.2  11068  2948 pts/2    S+   23:02   0:00 vim file2

[root@localhost~]# kill 4362
[root@localhost~]# kill -9 4363

[root@localhost~]# killall vim                //給所有vim進程發送信號
[root@localhost~]# killall httpd

信號測試18,19

[root@localhost~]# ps aux |grep sshd
root      5571  0.0  0.0  64064  1164 ?                Ss   09:35   0:00 /usr/sbin/sshd

[root@localhost~]# kill -STOP 5571
[root@localhost~]# ps aux |grep sshd
root      5571  0.0  0.0  64064  1164 ?                Ts   09:35   0:00 /usr/sbin/sshd

[root@localhost~]# kill -cont 5571
[root@localhost~]# ps aux |grep sshd
root      5571  0.0  0.0  64064  1164 ?                Ss   09:35   0:00 /usr/sbin/sshd

[yang@iZm5eiwihahzq6ds23gbf6Z ~]$ ps aux |grep crond
root     22319  0.0  0.1 124140  1568 ?        Ss   14:54   0:00 /usr/sbin/crond -n
yang     22427  0.0  0.0 112648   964 pts/2    R+   15:07   0:00 grep --color=auto crond
[yang@iZm5eiwihahzq6ds23gbf6Z ~]$ 
[yang@iZm5eiwihahzq6ds23gbf6Z ~]$ sudo kill -19 22319
[yang@iZm5eiwihahzq6ds23gbf6Z ~]$ ps aux |grep crond
root     22319  0.0  0.1 124140  1568 ?        Ts   14:54   0:00 /usr/sbin/crond -n
yang     22431  0.0  0.0 112648   964 pts/2    R+   15:07   0:00 grep --color=auto crond
[yang@iZm5eiwihahzq6ds23gbf6Z ~]$ 
[yang@iZm5eiwihahzq6ds23gbf6Z ~]$ sudo kill -cont 22319
[yang@iZm5eiwihahzq6ds23gbf6Z ~]$ ps aux |grep crond
root     22319  0.0  0.1 124140  1568 ?        Ss   14:54   0:00 /usr/sbin/crond -n
yang     22436  0.0  0.0 112648   960 pts/2    R+   15:08   0:00 grep --color=auto crond

踢出一個從遠程登錄到本機的用戶

[root@localhost~]# pkill --help
pkill: invalid option -- '-'
Usage: pkill [-SIGNAL] [-fvx] [-n|-o] [-P PPIDLIST] [-g PGRPLIST] [-s SIDLIST]
    [-u EUIDLIST] [-U UIDLIST] [-G GIDLIST] [-t TERMLIST] [PATTERN]
[root@localhost~]# pkill -u alice

[root@localhost~]# w
 15:46:44 up  2:19,  4 users,  load average: 0.17, 0.12, 0.08
USER     TTY      FROM              LOGIN@   IDLE   JCPU   PCPU WHAT
root     tty1     :0               21:32     ?     4:22   4:22  /usr/bin/Xorg :
root     pts/0    :0.0             15:46    0.00s  0.00s  0.00s w
root     pts/3    172.16.8.100     15:46    2.00s  0.01s  0.00s sleep 50000

[yang@iZm5eiwihahzq6ds23gbf6Z ~]$ w
 15:17:25 up  5:42,  3 users,  load average: 0.00, 0.01, 0.05
USER     TTY      FROM             LOGIN@   IDLE   JCPU   PCPU WHAT
yang     pts/0    123.120.22.32    15:00   21.00s  0.00s  0.00s -bash
yang     pts/1    123.120.22.32    15:00    5.00s  0.00s  0.00s w
yang     pts/2    123.120.22.32    12:04   13.00s  0.12s  0.02s vim file1
[yang@iZm5eiwihahzq6ds23gbf6Z ~]$ pkill -t pts/2                //終止pts/2上所有進程
[yang@iZm5eiwihahzq6ds23gbf6Z ~]$ pkill -9 -t pts/2            //終止pts/2上所有進程  並結束該pts/2

[yang@iZm5eiwihahzq6ds23gbf6Z ~]$ w
 15:20:59 up  5:45,  3 users,  load average: 0.00, 0.01, 0.05
USER     TTY      FROM             LOGIN@   IDLE   JCPU   PCPU WHAT
yang     pts/0    123.120.22.32    15:00    3:55   0.00s  0.00s -bash
yang     pts/1    123.120.22.32    15:00    3.00s  0.01s  0.00s w
yang     pts/2    123.120.22.32    15:20    3.00s  0.00s  0.00s -bash
[yang@iZm5eiwihahzq6ds23gbf6Z ~]$ sudo pkill -u yang

進程優先順序nice

Linux 進程調度及多任務

  每個CPU(或CPU核心)在一個時間點上只能處理一個進程,通過時間片技術,Linux實際能夠運行的進程(和線程數)可以超
出實際可用的CPU及核心數量。Linux內核進程調度程式將多個進程在CPU核心上快速切換,從而給用戶多個進程在同時運行的印象。

相對優先順序 nice

  由於不是每個進程都與其他進程同樣重要,可告知進程調度程式為不同的進程使用不同的調度策略。常規系統上運行的大多
數進程所使用的調度策略為 SCHED_OTHER (也稱為SCHED_NORMAL),但還有其它一些調度策略用於不同的目的。

SCHED_OTHER 調度策略運行的進程的相對優先順序稱為進程的 nice 值,可以有40種不同級別的nice值。

nice 值越高: 表示優先順序越低,例如+19,該進程容易將CPU 使用量讓給其他進程。
nice 值越低: 表示優先順序越高,例如-20,該進程更不傾向於讓出CPU。

查看進程的nice級別

1. 使用top查看nice級別
NI: 實際nice級別
PR: 將nice級別顯示為映射到更大優先順序隊列,-20映射到0,+19映射到39

3. 使用ps查看nice級別
[root@tianyun ~]# ps axo pid,command,nice --sort=-nice
[root@tianyun ~]# ps axo pid,command,nice,cls --sort=-nice
TS 表示該進程使用的調度策略為SCHED_OTHER

啟動具有不同nice級別的進程

啟動進程時,通常會繼承父進程的 nice級別,預設為0。

[root@tianyun ~]# nice -n -5 sleep 6000 & 
[root@tianyun ~]# ps axo command,pid,nice |grep sleep

[root@tianyun ~]# nice -n -20 systemctl start httpd
[root@tianyun ~]# ps axo pid,command,nice,cls |grep httpd
11116 /usr/sbin/httpd             -20  TS
11119 /usr/sbin/httpd             -20  TS
11120 /usr/sbin/httpd             -20  TS
11121 /usr/sbin/httpd             -20  TS
11122 /usr/sbin/httpd             -20  TS
11123 /usr/sbin/httpd             -20  TS
11124 /usr/sbin/httpd             -20  TS
11125 /usr/sbin/httpd             -20  TS
11126 /usr/sbin/httpd             -20  TS

更改現有進程的nice級別

1. 使用top更改nice級別
r    調整進程的優先順序(Nice Level) (-20高)  ---0--- (19低)

2. 使用shell更改nice級別
[root@tianyun ~]# sleep 7000 &
[3] 10089
[root@tianyun ~]# renice -20 10089
10089: old priority 0, new priority -20

作業控制 jobs

  作業控制是一個命令行功能,允許一個shell 實例來運行和管理多個命令。
如果沒有作業控制,父進程fork()一個子進程後,將sleeping,直到子進程退出。
使用作業控制,可以選擇性暫停,恢復,以及非同步運行命令,讓 shell 可以在子進程運行期間返回接受其他命令。

foreground, background, and controlling terminal

foreground: 前臺進程是在終端中運行的命令,該終端為進程的控制終端。前臺進程接收鍵盤產生的輸入和信號,並允許從終端讀取或寫入到終端。
background: 後臺進程沒有控制終端,它不需要終端的交互。

示例

[root@localhost~]# sleep 3000 &                          //運行程式(時),讓其在後臺執行
[root@localhost~]# sleep 4000                            //^Z,將前臺的程式掛起(暫停)到後臺
[2]+  Stopped             sleep 4000

[root@localhost~]# ps aux |grep sleep
root      8895  0.0  0.0 100900   556 pts/0    S    12:13   0:00 sleep 3000
root      8896  0.0  0.0 100900   556 pts/0    T    12:13   0:00 sleep 4000

[root@localhost~]# jobs                                     //查看後臺作業
[1]-  Running                sleep 3000 &
[2]+ Stopped               sleep 4000

[root@localhost~]# bg %2                                //讓作業2在後臺運行
[root@localhost~]# fg %1                                //將作業1調回到前臺

[root@localhost~]# kill %1                                //kill 1,終止PID為1的進程

[root@localhost~]# (while :; do date; sleep 2; done) &  //進程在後臺運行,但輸出依然在當前終端

[root@localhost~]# (while :; do date; sleep 2; done) &>/dev/null &

 


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

-Advertisement-
Play Games
更多相關文章
  • 相信很多微信用戶在使用微信給朋友,同事發送相冊中的文件時,微信會顯示你手機中的視頻文件,這樣很不方便. 如果要完全不顯示視頻文件: 隨便在手機中建立一個文件夾,名字叫 ".nomedia",把視頻文件丟進去就行了. 如何隱藏你希望隱藏的視頻文件: 隨便在手機中建立一個文件夾,名字叫 ".nomedi ...
  • Python序列內置類型之元組類型詳解 1.元祖的概念 Python中的元組與列表類似,都是一個序列,不同的是元組的元素不能修改而已。 2.元組的創建 元組使用小括弧,列表使用方括弧。 註意:元組中只包含一個元素時,需要在元素後面添加逗號,否則括弧會被當作運算符使用。 3.Python元組操作 1. ...
  • 跳槽不算頻繁,但參加過不少面試(電話面試、face to face面試),面過大/小公司、互聯網/傳統軟體公司,麵糊過(眼高手低,缺乏實戰經驗,掛掉),也面過人,所幸未因失敗而氣餒,在此過程中不斷查缺補漏,養成了踏實、追本溯源、持續改進的習慣,特此將自己經歷過、構思過的一些面試題記錄下來,如果答案有 ...
  • 當一個Action完成它的任務後,通常需要返回一個實現IActionResult的對象,而最常見的就是View或者ViewResult,所謂的視圖對象。那麼視圖與最終所看到的頁面之間的聯繫又是怎樣形成的,這便是本文想要探討的問題。 在ResourceInvoker類之中,可以找到下列的代碼。這些代碼 ...
  • .net 信息採集ajax數據 關於.net信息採集的資料很多,但是如果採集的網站是ajax非同步載入數據的模式,又如何採集呢?今天就把自己做信息採集時,所遇到的一些問題和心得跟大家分享一下。 採集網站的幾種方式與利弊: 利用系統自帶HttpWebRequest對象,採集網站內容,優點是採集效率快,但 ...
  • 1、 閉包的含義 首先閉包並不是針對某一特定語言的概念,而是一個通用的概念。除了在各個支持函數式編程的語言中,我們會接觸到它。一些不支持函數式編程的語言中也能支持閉包(如java8之前的匿名內部類)。 在看過的對於閉包的定義中,個人覺得比較清晰的是在《JavaScript高級程式設計》這本書中看到的 ...
  • Asp.Net MVC EF之二:原生EF插入,更新數據的正確方法,EF更新數據將之前修改的欄位也還原了 ...
  • 實驗說明: 雲計算的發展使得桌面上雲,windows 10就必不可少,這一章就如何製作QCOW2鏡像文件並優化進行說明。 實驗環境: 宿主機系統 :Fedora 28 WorkStation 虛擬機管理器 :Virt-Manager 1.5.1 虛擬機配置 :Windows10 1709 virbr ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...