linux編程如何避免使用到已經被占用的端口號?
回答本行業問題
Linux下服務一般是通過shell腳本來啟動程序或者服務,在shell腳本啟動時,可以使用命令來查詢,本服務或程序端口是否被其他程序占用,可以使用netstat命令。
netstat比如我們查詢80端口是否被占用,命令如下:
[root@api ~]# netstat -anp|grep 80
從上面可以看出80端口已經被nginx監聽。
netstat具體的參數如下,【-a】顯示所有的socket連接,【-n】不使用域名,而使用ip顯示,【-p】顯示監聽此socket的進程名稱,【grep】是過濾包含80字符的匹配項。
簡單函數封裝我們在寫腳本時盡量將經常使用的腳本封裝成函數,以便其他程序也可以調用這個函數,如下面的腳本,實現端口的查詢函數【入參1=端口】:
我們用幾個端口測試一下,可以看出上面我的端口被nginx占用
良好的編寫代碼習慣在linux編程寫程序時,盡量不要將監聽的端口、IP、網卡接口等可能會發生變化的參數,寫死到代碼中,可以定義一個配置文件,把經常變化的參數寫入配置文件,在程序啟動或者調用時,加載配置文件來讀取參數。
以上回答希望能夠幫助到你。