雲中樹莓派(1):環境準備

 

1. 設備準備

準備好的設備包括:ubuntu

  • 樹莓派3B,來自某寶
  • 電源,來自某寶
  • 8G 10級 microSD 卡(TF卡),包括讀卡器,來自某東
  • 散熱片兩個,來自某寶
  • SDH22 溫度溼度傳感器,來自某寶 

樹莓派確實和一張信用卡通常大小,以下圖所示。  它有4個USB,1個有線網口,1個HDMI,1個音頻輸出,一個電源接口,一個TF卡插口。注意 TF卡接口在USB口的另外一面。網絡

2. 系統安裝與基本配置

2.1 系統下載

到樹莓派官網 https://www.raspberrypi.org/downloads/,下載官方系統鏡像 RaspberryPi。下載下來的是一個 zip 文件。app

 

2.2 SD 卡刻錄

https://sourceforge.net/projects/win32diskimager/files/latest/download 下載刻錄工具  win32diskimager.exe。把樹莓派鏡像 zip 文件解壓,而後進行鏡像寫入:ssh

將 SD卡插入樹莓派的SD卡口,而後接通電源,觀察指示燈。下表是指示燈表示的各類狀態:tcp

第一次失敗,只有紅燈亮,綠色燈不閃爍。從新寫入鏡像。工具

首先根據 https://kb.sandisk.com/app/answers/detail/a_id/14827/~/using-sd-formatter-tool-to-restore-full-capacity-on-sdhc%2Fsdxc-cards 這個教程對SD卡作格式化:佈局

格式化以前,能看到兩個盤符,格式化以後,就只能看到一個盤符了。spa

而後根據網上建議,把樹莓派解壓後的鏡像 .img 文件放到不帶中文字符的路徑下,從新刻錄,而後再通電。此時,能觀察到綠燈間歇性閃爍。.net

可是,此時沒有網線,沒有SSH,還沒法登陸系統。3d

2.3 無線網絡準備和SSH鏈接

將 SD 卡插入Windows 系統後,能看到兩個盤,其中一個是 boot(H) 盤。在其根目錄下,建立文件  wpa_supplicant.conf,內容以下:

country=GB
ctrl_interface=DIR=/var/run/wpa_supplicant GROUP=netdev
update_config=1
network={
   ssid="<wifi 熱點名字>"
   psk="<wifi密碼>"
} 

而後,在同一個目錄下,  新建一個名爲 ssh 的空白文件。將 SSD 卡插入樹莓派,從新上電。

使用 Advanced IP Scanner 掃描局域網內的IP,很容易就能看到樹莓派。以下圖所示:

使用 SSH 登陸樹莓派。默認用戶名和密碼爲  pi/raspberry:

2.4 基本配置

運行 raspi-config 命令,可進行一些基本配置:

 

修改時區:選擇 4.Localisation Options 找到第二個 TimeZone,選擇Asia shanghai
修改鍵盤佈局:選擇 4.Localisation Options, 第三個,將 鍵盤佈局 改成US 美式鍵盤(由於樹莓派是英國產的 默認是英式鍵盤 而中國默認的是和美國同樣的美式鍵盤)
最後一個  Wifi地區  選中國

2.5 遠程桌面配置

首先要更新系統:

sudo apt-get update
sudo apt-get upgrade

而後安裝 xrdp:

sudo apt-get install xrdp

設置其開機自動啓動:

sudo systemctl enable xrdp

而後就可使用 Windows mstsc 遠程登陸樹莓派了:

效果還蠻不錯:

 

3. 外網SSH 訪問

當前樹莓派在內網中,能夠經過Wift訪問公網,可是沒法從公網訪問到。參考這篇文章,利用 SSH反向隧道,實現從外網SSH訪問樹莓派。

環境準備:

  • 外網須要有一臺有公網IP 的 VPS,代號A,公網IP地址爲 A1.A2.A3.A4
  • 內網中的能夠訪問外網的樹莓派,代號B

樹莓派上的配置:

  • 首先安裝 autossh 軟件: apt install autossh
  • 建立用戶 autossh,產生其 ssh key 文件,拷貝到機器A 上,須要可以從 B 無密碼SSH到A。
   useradd -m autossh
   passwd autossh
   su - atuossh
   ssh-keygen -t 'rsa' -C 'autossh@raspberrypi'
   ssh-copy-id ubuntu@A1.A2.A3.A4
  • 建立文件  /lib/systemd/system/autossh.service,內容以下:
[Unit]
Description=Auto SSH Tunnel
After=network-online.target
[Service]
StartLimitIntervalSec=60
User=autossh
Type=simple
ExecStart=/usr/bin/autossh -p 22 -M 8889 -NR '*:8888:127.0.0.1:22' ubuntu@A1.A2.A3.A4 -i /home/autossh/.ssh/id_rsa
ExecReload=/bin/kill -HUP $MAINPID
KillMode=process
Restart=always
[Install]
WantedBy=multi-user.target
WantedBy=graphical.target
  • 啓動該服務,確保其狀態爲 active
chmod 644 /lib/systemd/system/autossh.service
systemctl enable autossh
systemctl start autossh
systemctl status autossh
  • 此時,能看到相關進程:
autossh   3709     1  0 Aug07 ?        00:00:00 /usr/lib/autossh/autossh -p 22 -M 8889 -NR *:8888:127.0.0.1:22 ubuntu@*.*.*.* -i /home/autossh/.ssh/id_rsa
autossh   3712  3709  0 Aug07 ?        00:00:00 /usr/bin/ssh -L 8889:127.0.0.1:8889 -R 8889:127.0.0.1:8890 -p 22 -NR *:8888:127.0.0.1:22 -i /home/autossh/.ssh/id_rsa ubuntu@*.*.*.*
  • 在A 上,能看到在 8888 端口上有 ssh 監聽:
tcp        0      0 0.0.0.0:8888            0.0.0.0:*               LISTEN      18324/sshd: ubuntu

SSH訪問:

  • 在A 上,ssh 到 8888 端口,利用樹莓派的用戶名和密碼,能夠登陸到樹莓派:

  • 還能夠直接在外網利用A 的公網IP 和樹莓派的用戶名密碼直接SSH:

  

參考連接:

歡迎你們關注個人我的公衆號:

相關文章
相關標籤/搜索