connect ECONNREFUSED 127.0.0.1:80 at TCPConnectWrap.afterConnect [as oncomplete] (net.js:1113:14)
async asyncData
方法去請求後臺地址刷新頁面就沒問題,若是使用了該方法去請求後臺刷新頁面就報上面的異常。nuxt.config.js
中的proxy
,結果沒用。async asyncData
向服務端發送請求是要填寫完整的http://服務器ip:端口/api
,可是我有proxy
代理爲何還要填寫完整的地址呢?最後修改package.json
中的地址html
host
設置爲127.0.0.1
或者localhost
後項目啓動沒問題,可是頁面沒法打開。host
設置爲服務器內網ip地址
後項目啓動沒問題,頁面正常打開,刷新沒有async asyncData
方法的頁面正常,刷新有這個方法的頁面就包異常了connect ECONNREFUSED 127.0.0.1:80 at TCPConnectWrap.afterConnect [as oncomplete] (net.js:1113:14)
,host
設置爲0.0.0.0
後,頁面後項目啓動正常,頁面刷新正常。查看進程和端口顯示爲服務器內網ip:80
也是正常的。在package.json中修改host爲0.0.0.0
node
"config": { "nuxt": { "host": "0.0.0.0", "port": "80" } }
0.0.0.0
、內網ip、公網ip,127.0.0.1
的講解其實只想咱們的服務器自己的ip有不少,公網ip,內網ip,localhost,127.0.0.1,若是生產環境中咱們的node服務指定了內網ip,那麼利用公網ip訪問時就會出錯。而 0.0.0.0
在服務器中指的是一個集合,包含全部指向自身的ip集合ios
摘自 https://www.cnblogs.com/sddai...編程
127.0.0.1和0.0.0.0地址的區別
在進行網絡編程時,會將服務器的IP地址設置爲127.0.0.1。而後綁定端口,開始監聽。可是對於服務器來講,除了127.0.0.1,還有內網IP和公網IP,綁定本地的話只能局域網傳輸,因此,應該怎麼綁定?json
先複習一下IP類型:axios
IP地址一共分爲5類,即A~E,它們分類的依據是其net-id所佔的字節長度以及網絡號前幾位。
- A類地址:網絡號佔1個字節。網絡號的第一位固定爲0。
- B類地址:網絡號佔2個字節。網絡號的前兩位固定爲10。
- C類地址:網絡號佔3個字節。網絡號的前三位固定位110。
- D類地址:前四位是1110,用於多播(multicast),即一對多通訊。
- E類地址:前四位是1111,保留爲之後使用。
還有些特殊地址:
- 127.0.0.1:迴環地址。該地址指電腦自己,主要預留測試本機的TCP/IP協議是否正常。只要使用這個地址發送數據,則數據包不會出如今網絡傳輸過程當中。
- 10.x.x.x、172.16.x.x~172.31.x.x、192.168.x.x:這些地址被用作內網中。用作私網地址,這些地址不與外網相連。
- 255.255.255.255:廣播地址
- 0.0.0.0:這個IP地址在IP數據報中只能用做源IP地址,這發生在當設備啓動時但又不知道本身的IP地址狀況下。
由此看,兩個都屬於特殊地址。api
IPV4中,0.0.0.0地址被用於表示一個無效的,未知的或者不可用的目標。
* 在服務器中,0.0.0.0指的是本機上的全部IPV4地址,若是一個主機有兩個IP地址,192.168.1.1 和 10.1.2.1,而且該主機上的一個服務監聽的地址是0.0.0.0,那麼經過兩個ip地址都可以訪問該服務。
* 在路由中,0.0.0.0表示的是默認路由,即當路由表中沒有找到徹底匹配的路由的時候所對應的路由。服務器用途:
- DHCP分配前,表示本機。
- 用作默認路由,表示任意主機。
- 用作服務端,表示本機的任意IPV4地址。
localhost:
只是一個域名,能夠表明任何IP地址。默認是127.0.0.1 ,在/etc/hosts文件下。
在實際應用中,通常咱們在服務端綁定端口的時候能夠選擇綁定到0.0.0.0,這樣個人服務訪問方就能夠經過個人多個ip地址訪問個人服務。
好比我有一臺服務器,一個外網A,一個內網B,若是我綁定的端口指定了0.0.0.0,那麼經過內網地址或外網地址均可以訪問個人應用。網絡