“能用esp8266弄一個遠程開電腦的教程嗎?需要設置路由器嗎?公司路由器設置不了。”
當然可以!而且很簡單~
ESP8266是一個非常適合用于物聯網和家庭智能項目的帶wifi模塊的單片機。它的售價非常低廉,只需大約10塊
這個問題可以拆解成兩部分:
問題一:訪問內網設備
問題二:控制電腦開機
可以使用WOL(Wake on Lan)網絡喚醒功能。
這里我們就利用阿里云物聯網平臺來控制內網設備,再利用ESP8266 NodeMCU這個性價比極高的單片機發出WOL網絡喚醒的魔法包來啟動目標電腦~
ESP8266的介紹和入門指南可以參見我上次寫的這篇文章:十塊錢入門物聯網!ESP8266新手指南
下面我們就看看具體怎么設置吧~
首先進入阿里云物聯網平臺的控制臺首頁,沒有賬號的朋友需要先注冊賬號。
點擊設備-產品-創建產品。
給新建的產品起一個名字,然后選擇自定義品類,并設置為直連設備,其他設置如圖:
然后點擊進入剛才新建成功的產品內,點擊產品-Topic類列表-自定義Topic-定義Top類,來新建一個Topic類。
在新建Topic類的對話框中,設備權限選擇“訂閱”,名字輸入“device_boot”。選訂閱權限是因為我們的設備只需要接受消息就可以了,不需要發送消息。后面我們需要用到這個topic來給我們的esp8266發送消息來控制電腦開機~
有了產品之后,我們還需要給產品添加設備:點擊設備-添加設備。
在添加設備對話框,選擇剛才新建的產品,然后給設備起一個名字。
新建完設備之后,點擊剛才新建出的設備的查看按鈕來進入設備詳情頁。
進入設備詳情頁后,點擊DeviceSecret的查看按鈕,會得到3個碼,把他們復制出來并保存好,后面我們會用到這三個碼來把esp8266連接到阿里云物聯網平臺。
對于需要被網絡喚醒的電腦,按開機鍵開機,然后不停地點擊進入BIOS設置的相關熱鍵。進入BIOS設置的熱鍵一般為DEL, F12等。進入相關設置頁面后,打開網絡喚醒(Wake on Lan)功能,或者叫做PCIE設備喚醒(Wake on PCIE Devices)。
這樣即使在電腦關機之后,只要電源線和網線沒有拔掉,電腦接受到其他內網設備(例如ESP8266)發出的的WOL信號,就會開機了!
另外,為了定位需要被喚醒的電腦,我們需要獲取目標電腦的網卡MAC地址,以windows系統為例:
按win鍵+R,輸入cmd,回車
然后,輸入ipconfig /all,回車,圈出的就是該機器的網卡MAC地址
首先參照我上次寫的ESP8266新手指南,設置好基本開發環境,這里不再贅述:
十塊錢入門物聯網!ESP8266新手指南
用Arduino IDE點擊.ino文件打開相關代碼(具體代碼包和用到的庫和工具我會打包附于文后):
/**
* Wake on Lan using Aliyun IOT & ESP8266.
* 通過ESP8266 NodeMCU和阿里云IOT平臺實現對內網主機的網絡喚醒(WOL)
*
* 零度橙子OrangeZero Copyright @ 2020
*/
#include <ESP8266WiFi.h>
#include <WiFiUDP.h>
#include <PubSubClient.h> // !!! set MQTT_MAX_PACKET_SIZE=256; MQTT_KEEPALIVE=60 in PubSubClient.h due to restriction in Aliyun IOT mqtt
#include <WakeOnLan.h>
#include "aliyun_mqtt.h" // https://github.com/legenddcr/aliyun-mqtt-arduino
#define WIFI_SSID "ssid"// >>> 替換為自己的wifi名稱::ESP8266只支持2.4G的wifi,不支持5G頻段的wifi
#define WIFI_PASSWD "pwd"// >>> 替換為自己的wifi密碼
#define PRODUCT_KEY "a1G8xxxxxx" // >>> 替換為自己阿里云iot的PRODUCT_KEY
#define DEVICE_NAME "dev1" // >>> 替換為自己的阿里云的DEVICE_NAME
#define DEVICE_SECRET "xxxxxxxxxxxxxxxxxxxxxxxx"// >>> 替換為自己阿里云的DEVICE_SECRET
#define DEV_VERSION "0.0.1" //固件版本信息
#define ALINK_BODY_FORMAT "{\"id\":\"123\",\"version\":\"1.0\",\"method\":\"%s\",\"params\":%s}"
#define ALINK_TOPIC_PROP_POST "/sys/" PRODUCT_KEY "/" DEVICE_NAME "/thing/event/property/post"
#define ALINK_TOPIC_PROP_POSTRSP "/sys/" PRODUCT_KEY "/" DEVICE_NAME "/thing/event/property/post_reply"
#define ALINK_TOPIC_PROP_SET "/sys/" PRODUCT_KEY "/" DEVICE_NAME "/thing/service/property/set"
#define ALINK_METHOD_PROP_POST "thing.event.property.post"
#define ALINK_TOPIC_DEV_INFO "/ota/device/inform/" PRODUCT_KEY "/" DEVICE_NAME ""
#define ALINK_VERSION_FROMA "{\"id\": 123,\"params\": {\"version\": \"%s\"}}"
#define ALINK_TOPIC_DEVICE_BOOT PRODUCT_KEY "/" DEVICE_NAME "/user/device_boot"
const char *MACAddress="04:D9:F5:83:03:EF"; // >>> 替換成需要被喚醒的機器的MAC地址
IPAddress computer_ip(255, 255, 255, 255);
unsigned long lastMs=0;
WiFiClient espClient;
PubSubClient mqttClient(espClient);
WiFiUDP UDP;
WakeOnLan WOL(UDP);
void init_wifi(const char *ssid, const char *password)
{
WiFi.mode(WIFI_STA);
WiFi.begin(ssid, password);
while (WiFi.status() !=WL_CONNECTED)
{
Serial.println("WiFi does not connect, try again ...");
delay(500);
}
Serial.println("Wifi is connected.");
Serial.println("IP address: ");
Serial.println(WiFi.localIP());
}
void mqtt_callback(char *topic, byte *payload, unsigned int length)
{
Serial.print("Message arrived [");
Serial.print(topic);
Serial.print("] ");
payload[length]='\0';
Serial.println((char *)payload);
if (strstr(topic, ALINK_TOPIC_DEVICE_BOOT)) {
Serial.print("sending WOL magic packet to: ");
Serial.println(MACAddress);
WOL.sendMagicPacket(MACAddress);
}
}
void mqtt_version_post()
{
char param[512];
sprintf(param, "{\"id\": 123,\"params\": {\"version\": \"%s\"}}", DEV_VERSION);
Serial.println(param);
mqttClient.publish(ALINK_TOPIC_DEV_INFO, param);
}
void mqtt_check_connect()
{
Serial.println("checking mqtt connection...");
while (!mqttClient.connected())
{
while (connect_aliyun_mqtt(mqttClient, PRODUCT_KEY, DEVICE_NAME, DEVICE_SECRET))
{
Serial.println("MQTT connect succeed!");
mqttClient.subscribe(ALINK_TOPIC_PROP_SET);
mqttClient.subscribe(ALINK_TOPIC_DEVICE_BOOT);
Serial.println("subscribe done");
mqtt_version_post();
}
}
}
void setup()
{
/* initialize serial for debugging */
Serial.begin(115200);
Serial.println("Demo Start");
init_wifi(WIFI_SSID, WIFI_PASSWD);
mqttClient.setCallback(mqtt_callback);
}
// the loop function runs over and over again forever
void loop()
{
if (millis() - lastMs >=20000)
{
lastMs=millis();
mqtt_check_connect();
}
mqttClient.loop();
unsigned int WAIT_MS=2000;
delay(WAIT_MS); // ms
//Serial.println(millis() / WAIT_MS);
}
注意,代碼需要替換三處地方:
需要額外安裝的依賴庫有(具體用到的庫我會打包附于文后):
大家可以通過arduino IDE的包管理器來安裝這些包,如果網絡不好下不動的話,也可以下載我打包好的zip包,再導入到arduino IDE。
需要注意的是,由于阿里云物聯網平臺的MQTT協議的限制,PubSubClient.h文件內定義的MQTT_MAX_PACKET_SIZE需要設置為256,MQTT_KEEPALIVE需要設置為60。不然于阿里云物聯網平臺的通訊會報錯。從arduino IDE下載PubSubClient庫的朋友需要修改一下這兩個值。使用我給的zip包的朋友,不需要額外修改了,因為我已經修改好了。
點擊按鈕上傳代碼到ESP8266,并等待上傳完畢
打開arduino IDE中的,工具-串口監視器,確認傳輸速率為115200波特。查看串口調試信息,確認程序運行正常。
接下來,我們只需到阿里云物聯網平臺,點擊之前創建的設備,然后找到自定義Topic,找到我們之前新建的Topic:device_boot,點擊發布消息。
在新建的對話框中,我們就可以給我們的ESP8266發送消息了!
點擊確認發送消息之后,我們可以通過串口監視器看到,WOL信號已經發出。而且內網的目標電腦也開機了!
以后,只要ESP8266保持通電,它就會自動連接阿里云物聯網平臺。我們就可以隨時隨地通過阿里云物聯網平臺的控制臺來遠程啟動內網的電腦了!
有興趣的同學甚至可以利用阿里云物聯網平臺制作一個好看的遠程開機界面或者是在家里遠程開啟公司電腦的實體按鍵~
大家還有什么想要做的物聯網或者智能家居項目呢?在下面留言告訴我吧~
我是零度橙子,科技達人,谷歌認證云計算架構師,AWS認證devops專家,歡迎大家關注我,了解有用有趣的科技知識~
過我們之前文章的朋友都知道,華為之前已經對外發布了旗下的首款云手機—云鯤鵬手機,雖然叫手機,但這款產品與市面上的傳統手機完全不同。CPU、內存、存儲等等硬件全都存放在華為的服務器中,我們只需要將一塊屏幕連接網絡即可使用。
如果我告訴你,現在有一款與云手機運行方式差不多,隨手拿個卡片大小的東西就能代替電腦,你會不會感興趣?
今天上午,在阿里巴巴舉辦的第12屆云棲大會上,阿里云總裁張建鋒正式發布了阿里的首款云電腦—無影。與華為的云手機大致相同,這款電腦沒有本地CPU、硬盤、顯卡、內存、顯示器等等設備,全部都在云端。
不過這款云電腦的運行方式就比較特殊了,阿里為用戶專門制造了一個叫做C-Key的啟動硬件,僅有一張卡片大小。當用戶想要使用云電腦時,只需要在這個卡片上進行指紋識別,并且連接到顯示屏和網絡即可隨時使用。
乍一看是不是沒啥感覺?別慌,我來給你簡單講解一下它的優勢。
相比個人PC來說,你需要的不僅僅是顯示器和網絡,你還需要另行搭配處理器、內存、顯卡、硬盤、電源、機箱等等設備,而想要使用這款云電腦,你僅僅需要兩個東西:互聯網和顯示器。
另外,云電腦還具有很強的彈性擴充屬性。比如你的個人電腦在裝機時,選擇的是500G硬盤,如果工作上突然臨時有個超大文件項目導致空間不足,你就只能刪除文件,或者再去買一個硬盤裝上。花錢就不說了,主要的是時間上的浪費。
當然,在阿里的無影云電腦上,你不僅可以隨時增加存儲空間,還可以隨時擴充網絡和計算力。若有臨時的超高算力需求的時候,單應用資源可彈性擴展到高達104核CPU、1.5T內存。
相比傳統電腦的三、五年使用壽命,無影云電腦還可以做到無限升級,不需要更換硬件設備。而在系統方面,它還能實現跨平臺、跨終端、Windows/Linux應用無縫切換。最最主要的是,它的價格大約只是同等性能PC的一半。
說了這么多,大家可能還是不太清楚實現方式,張建鋒也放出了一段視頻來呈現。這里吐槽一下,雖然是為了讓我們更好的理解應用場景,但這段視頻內所使用的顯示設備還是有點過于未來化了,總感覺是把《鋼鐵俠》里的高科技全都拿出來了……
簡單點來說就是,在你通過指紋識別激活并啟動了那張C-Key后,與它連接的顯示設備(比如手機、平板、電視、投影,甚至是VR眼鏡)通上網絡后,即可直接進入操作系統進行游戲、動畫渲染、制圖設計、軟件開發等等操作。
值得注意的是,這個使用場景并不受地點、時間的限制,只要有顯示設備和網絡,那你隨時都可以啟動并使用。
張建鋒還表示,用戶在云端所保存的所有數據文件,都無須擔心數據丟失,都是與阿里云數據中心享有同級別的安全防護能力。
不過遺憾的是,這個產品暫時只會面向企業出售,相信發展到一定程度后,未來肯定會有個人版本出現。
怎么樣,你覺得這個電腦如何?
運維工程師的日常工作中,經常需要登錄到服務器上對應用部署和維護,配置修改是很常規操作。但是在日常運維工作中,經常也會遭遇“滑鐵盧”,當出現無法遠程連接服務器的時候,我們需要沉著冷靜,耐心分析報錯的癥結,方能更好的定位和排除問題。
今天百曉生就阿里云服務器ECS無法遠程連接的問題,分享一波運維必備的問題排查方法,認同小編的童鞋,文末【點贊+再看】哦~
說明:以下操作在CentOS 6.5 64位操作系統中進行過測試
確認是否存在CPU負載過高的情況
確認公網帶寬是否不足
無法遠程連接可能是公網帶寬不足導致的,具體排查方法如下:
確認內存是否不足
遠程連接輸入用戶密碼登錄后,不能正常顯示桌面直接退出,也沒有錯誤信息。這種情況可能是服務器內存不足導致的,需要查看一下服務器的內存使用情況。具體操作如下:
客戶端無法正常登錄時,先使用不同的SSH客戶端基于相同賬戶信息進行登錄測試。如果能正常登錄,則判斷是客戶端配置問題,需要對客戶端配置或軟件運行情況做排查分析。關于如何使用SSH客戶端登錄Linux實例,您可以參見遠程連接Linux實例。
步驟一:使用管理終端登錄實例
無論何種原因導致無法遠程連接實例,請先嘗試用阿里云提供的遠程連接功能進行連接,確認實例還有響應,沒有完全宕機,然后再按原因分類進行故障排查。
步驟二:檢查客戶端本地網絡是否異常
確認是否存在用戶本地無法連接外網的故障。
步驟三:重啟實例
在確保登錄密碼正確的情況下,確認之前是否曾重置過密碼。檢查重置實例密碼后是否未重啟實例,如果存在實例密碼修改記錄,但無重啟實例記錄,則參考以下操作步驟重啟實例:
中間網絡包括網絡檢查和端口檢查。
網絡檢查
無法正常遠程連接Linux實例時,需要先檢查網絡是否正常。
1)網絡異常時,請參見網絡異常時如何抓取數據包進行排查。
2)當出現ping丟包或ping不通時,請參見使用ping命令丟包或不通時的鏈路測試方法進行排查。
3)如果出現間歇性丟包,ECS實例的網絡一直處于不穩定狀態時,請參見使用ping命令測試ECS實例的IP地址間歇性丟包進行解決。
4)系統內核沒有禁ping的情況下,使用ping命令測試ECS服務器,發現網絡不通,請參見Linux系統的ECS中沒有禁PING卻PING不通的解決方法。
網絡檢查正常后,進一步檢查端口是否正常。
1. 使用管理終端登錄實例,執行如下命令,編輯SSH配置文件。
vi /etc/ssh/sshd_config2. 找到“#port 22”所在行,檢查默認端口22是否被修改,且前面的“#”是否刪除,如果沒有刪除,可以把前面的“#”刪除,然后將22改為其它的端口,再保存退出即可。
說明:服務監聽能使用的端口范圍為0到65535,錯誤配置監聽端口會導致遠程桌面服務監聽失敗
3. 執行如下命令,重啟SSH服務。
/etc/init.d/sshd restart說明:也可執行service sshd restart命令,重啟SSH服務。
4. 使用Python自帶的Web服務器創建臨時的監聽端口進行測試。
python -m SimpleHTTPServer [$Port]
5. 如果ECS安全組規則中未放行修改后的端口號,需要將修改后的端口號添加到ECS安全組規則中。
說明:ECS的安全組規則中默認放行22端口。修改了遠程桌面的端口后,需要在安全組規則中放行修改后的端口號。
6. 通過上一步獲取的端口,參考如下命令,進行端口測試,判斷端口是否正常。
telnet [$IP] [$Port]
說明:
- [$IP]指Linux實例的IP地址。
- [$Port]指Linux實例的SSH端口號。
系統顯示類似如下,例如執行telnet 192.168.0.1 22命令,正常情況下,系統會返回服務端中SSH的軟件版本號。
檢查安全組配置,是否允許遠程連接的端口。
關注百曉生,笑談云計算