This repo outlines steps for working with a Raspberry Pi from your computer without a monitor, keyboard or mouse attached to the pi.
The instructions in this repo assume you'll be using the Raspbian OS, however these same instructions should work (perhaps with some modification) on other distros for the pi.
Also, so far I've only tested these steps on a Raspberry Pi 2 Model B+ and a Raspberry Pi 3 Model B. Not sure how it will work on other versions, but I would expect them to work with no or minimal modifications.
- Monitor attached to the Pi
- Keyboard attatched to the Pi
- Mouse attached to the Pi
- Another computer (Windows, macOS, Linux, Unix, really anything you can use to ssh into the Pi and prepare the Micro SD card with).
- A Micro SD card to load the Pi's Raspibian OS onto
- A way to mount the Micro SD card on your computer. This could be an integrated slot, an external USB reader, whatever.
- A 5V/2.5A or better Micro USB Power Supply to power the Pi
- A USB to TTL Serial FTDI Cable that supports 3.3v pins like this one from Adafruit: USB to TTL Serial Cable - Debug / Console Cable for Raspberry Pi
- An available Ethernet network and cable if you want to attach the Pi to it
- An available WiFi network and ssid/pwd if you want to attach the Pi to it
- Whatever else it is you want to hookup to your Pi.
- Preparing the OS Image and Booting the Pi
- Complete Adafruits USB to Serial Cable Tutorial
- Enable UART
- Boot the Pi
- Connect via Serial
- Update Raspbian
- Enable SSH & VNC
- Configuring the WiFi Network
- Set the Pi's Hostname
- Configure SSH Keys
- Configure the Display Resolution
- Connecting with VNC
- Install and Configure Samba
- Install and Configure Git
- OPTIONAL: Install Node.js
- OPTIONAL: Install the Azure IoT Device SDK for Python
- OPTIONAL: Configure SPI
If you already have a Pi up and running with an OS, you don't need to do this task. You can skip down to and move on.
-
Download the image for the Raspbian OS as a “.zip” (DON'T get NOOBs) from:
Note: There isn't anything wrong with NOOBS, but we don't need it, and this repo doesn't document the extra steps you'll need to use it, so just download the OS as a ".zip". Again though if you already have a Pi that you got running using NOOBs, you can certainly use it, just skip down to ... and continue!
-
If you need an older version, checkout: http://downloads.raspberrypi.org/raspbian/images/.
For example, the last version of Raspbian “Jessie” is at: http://downloads.raspberrypi.org/raspbian/images/images/raspbian-2017-07-05/2017-07-05-raspbian-jessie.zip
-
Download and install Etcher.io for your platform from https://etcher.io/
-
Insert the Micro-SD card for the pi into your computer
-
Use Etcher.io to flash the OS image “.zip” file to the SD card. It should be pretty obvious but:
- Pick the Raspbian OS ".zip" file you downloaded previously as the "Image"
- Select the Micro SD card you inserted above as the "Drive"
- Click the "Flash" button to flash the image onto the SD card. It'll take a few minutes to copy the whole image and verify it so please wait patiently until it is done.
I had started writing my own documentation to help you get the USB to Serial cable setup on your Pi and computer but I quickly realized I was really just stealing the work that Adafruit has already done so admirably. Plus, they'll probably be able to keep their docs up to date easier than I can so...
-
Complete "Adafruit's Raspberry Pi Lesson 5. Using a Console Cable" tutorial. Make sure to get all they way through, and when you're done, return here for more goodness.
If you completed the Adafruit Tutorial above you should have done this already, this step is just here for clarification purposes and to make sure that you complete it, otherwise you will likely have issues connecting to your Pi over the USB to Serial cable on newer versions of the Pi hardware and Operating System:
The clock speed on the Raspberry Pi 3s messes with the UART baud rate and will cause issues when we attempt to connect to it later with the USB to TTL Serial cable. To fix the problem, we need to edit the config.txt
file in the root of the Pi's SD card.
-
Make sure the Micro SD card with your Pi's OS is inserted into your computer, and locate the drive with the
boot
volume label. -
Locate the
config.txt
file in the root of theboot
partition and open the theconfig.txt
file in the text editor of your choice. -
Add the following two lines to the bottom of the
config.txt
file and save the changes:Note: You should ensure that the
enable_uart
setting isn't being set somewhere else in theconfig.txt
file already if this is a pre-existing OS image.# Enable UART enable_uart=1
-
Now you can safely eject the Micro SD card and insert it into your Raspberry Pi's SD card slot.
-
Ensure that, in the following order:
-
The Micro SD card is inserted into the SD Card slot on the back of the Pi
-
The USB to Serial cable to the Pi's leads are properly connected to the Pi
Lead Pin 5V Not Connected GND 6 (GND) TX 8 (UART0_TXD) RX 10 (UART0_RXD) -
The USB end of the USB to serial cable is connected to your computer
-
If you are on a Raspberry Pi 2 and want to use WiFi, that a WiFi dongle is plugged into a USB port.
-
If you want to use Ethernet, that the Ethernet cable is plugged into the Pi's Ethernet port, and to the network.
-
-
Once you have ensured all of the above, you can connect the Micro USB power supply to the Pi to boot it.
Again, you likely completed this already if you completed the Adafruit Tutorial above, but to ensure we are all starting from the same place:
-
Use the steps from the Test & Configure page of "Adafruit's Raspberry Pi Lesson 5. Using a Console Cable" tutorial to connect to your Raspberry Pi over the USB to Serial cable using a terminal program on your computer.
-
Login to the Pi:
Note: You may need to press the
ENTER
or key on your keyboard in the terminal once connected to get to the login prompt. Also, if you have already changed the credentials on your Pi, use those instead.- User Name:
pi
- Password:
raspberry
- User Name:
Before we start using our new Raspbian image, we should make sure it is up to date.
-
First, update the list of packages for
apt-get
sudo apt-get update
-
Then upgrade any packages that need it:
Note: Depending on your network speed, and the performance of your SD card, this can take some time to complete.
sudo apt-get -y upgrade
At this point you can connect to your pi only from a computer that is attached using the USB to Serial cable. If you want to connect to your pi over the network, you will need to enable ssh and/or vnc on the pi.
-
Ensure you are connected to your Pi over the USB to Serial cable in and logged in as described above.
-
From the command prompt run the following two commands to enable ssh & vnc (or optionally run just the command for the interface you want to enable )
Note: You can also enable the interfaces interactively by just running
sudo raspi-config
, navigating to5 Interfacing Options
and iteratively selecting and enabling each interface. The commands below just allow you to do it more directly and without any manual interaction required. See the raspi-config source code for other possible commands:# Enable the ssh and vnc interfaces on the pi # The "0" means "enable". "1" would mean "disable" sudo raspi-config nonint do_ssh 0 sudo raspi-config nonint do_vnc 0
-
You can optionally choose to enable other interfaces now as well, or as mentioned you can interactively run
sudo raspi-config
to configure other options likeHostname
,Localization Options
,Interfacing Options
and more.# Enable the ssh camera, i2c and spi interfaces # The "0" means "enable". "1" would mean "disable" sudo raspi-config nonint do_camera 0 sudo raspi-config nonint do_i2c 0 sudo raspi-config nonint do_spi 0
-
It appears that sometimes the SSH keys on the pi itself can be set wrong. See this post. If you are trying to ssh into your raspberry pi, and get an immediate response similar to
Connection closed by 192.168.2.58 port 22
, but with your pi's ip address, you can try the following steps to fix it:-
First, connect using the USB-to-Serial cable as described above, and login to your pi
-
List the the keys in the /etc/ssh folder using:
ls -al /etc/ssh/ssh*key*
-
If the key files are show zero byte file sizes, similar to this:
-rw------- 1 root root 0 Apr 8 03:30 ssh_host_dsa_key -rw-r--r-- 1 root root 0 Apr 8 03:30 ssh_host_dsa_key.pub -rw------- 1 root root 0 Apr 8 03:30 ssh_host_ecdsa_key -rw-r--r-- 1 root root 0 Apr 8 03:30 ssh_host_ecdsa_key.pub -rw------- 1 root root 0 Apr 8 03:30 ssh_host_ed25519_key -rw-r--r-- 1 root root 0 Apr 8 03:30 ssh_host_ed25519_key.pub -rw------- 1 root root 0 Apr 8 03:30 ssh_host_rsa_key -rw-r--r-- 1 root root 0 Apr 8 03:30 ssh_host_rsa_key.pub
-
Delete the zero'd out key files with:
sudo rm -r /etc/ssh/ssh*key*
-
Then re-configure the openssh-server component, which should create new key pairs:
sudo dpkg-reconfigure openssh-server
-
Verify the new keys by listing them again, and verifying non-zero byte file sizes:
ls -al /etc/ssh/ssh*key*
-rw------- 1 root root 227 Sep 13 11:13 /etc/ssh/ssh_host_ecdsa_key -rw-r--r-- 1 root root 174 Sep 13 11:13 /etc/ssh/ssh_host_ecdsa_key.pub -rw------- 1 root root 399 Sep 13 11:13 /etc/ssh/ssh_host_ed25519_key -rw-r--r-- 1 root root 94 Sep 13 11:13 /etc/ssh/ssh_host_ed25519_key.pub -rw------- 1 root root 1675 Sep 13 11:13 /etc/ssh/ssh_host_rsa_key -rw-r--r-- 1 root root 394 Sep 13 11:13 /etc/ssh/ssh_host_rsa_key.pub
-
Finally, verify you can ssh into the pi from a remote machine.
Note: If you were somehow successful in logging into pi from the remote machine previously, the pi's key will have changed and ssh will still fail. Remove the old pi key from the remote host by running the following ON THE REMOTE HOST, NOT THE PI, substituting your pi's ip address or hostname:
ssh-keygen -f "/home/bstateha/.ssh/known_hosts" -R "your.pi.ip.address"
-
The WiFi network configuration on the Pi is done using the wpa_supplicant by default. You can see this if you look at the default network interfaces configuration:
cat /etc/network/interfaces
You should see output similar to the following:
Note: The output below is from a Raspbian Jessie image. The
/etc/network/interfaces
file on Raspbian Stretch looks different. I haven't had time to suss out what is going on with Raspbian Stretch yet. Regardless, the information is still relevant to Raspbian Strech, and the steps work as documented.
# interfaces(5) file used by ifup(8) and ifdown(8)
# Please note that this file is written to be used with dhcpcd
# For static IP, consult /etc/dhcpcd.conf and 'man dhcpcd.conf'
# Include files from /etc/network/interfaces.d:
source-directory /etc/network/interfaces.d
auto lo
iface lo inet loopback
iface eth0 inet manual
allow-hotplug wlan0
iface wlan0 inet manual
wpa-conf /etc/wpa_supplicant/wpa_supplicant.conf
allow-hotplug wlan1
iface wlan1 inet manual
wpa-conf /etc/wpa_supplicant/wpa_supplicant.conf
Of specific interest is the configuration for wlan0
and wlan1
. Both are set to:
- Allow the wifi device to
allow-hotplug
. This is handy on a Pi 2 if you have to attach a WiFi dongle to the pi after it is already running. - Get their configuration from the
wpa-conf
via the/etc/wpa_supplicant/wpa_supplicant.conf
file.
Basically, that means you just need to edit /etc/wpa_supplicant/wpa_supplicant.conf
with the specifics for your WiFi network (ssid
,psk
, etc). However, you need to make sure you enter those values properly. So you have two choices to edit the contents of that file to specify your WiFi newtwork configuration:
- Using the
wpa_cli
- Manually editing the
wpa_supplicant.conf
file
What is a "supplicant"? Vocabulary.com explains it as follows:
A supplicant can be a fervently religious person who prays to God for help with a problem, and it can also be someone who begs earnestly for something he or she wants. A younger brother entreating his sister to be allowed in her tree house could be described as a supplicant. The Latin root word is supplicantem, "plead humbly."
Note the phrase "it can also be someone who begs earnestly for something he or she wants". In our case the wpa_supplicant
on the raspberry pi will be begging our WiFi Access point to allow it to connect. To do that we need to give the supplicant a few pieces of information:
- The WiFi Network SSID
- The WiFi Network passphrase / password / Pre-shared key, if there is one
-
From the prompt on the pi run:
sudo wpa_cli
-
Inside the
wpi_cli
interactive prompt, first set the country for your device. For example, here's how to specify theus
as the country (don't type the ">
"):> set country US
-
Next, you can scan for available wifi networks, and view the results:
> scan > scan_results
You should see a list of available WiFi Networks similar to the following (your list WILL be different and may wrap accross multiple lines):
bssid / frequency / signal level / flags / ssid f4:...:a3 2422 -66 [WPA2-PSK-CCMP][WPS][ESS] MyWiFiNetwork 38:...:bb 2412 -70 [WPA2-PSK-CCMP][WPS][ESS] SomeOtherWiFiNetwork ...
-
Find your network in the list, in this example we'll use
MyWiFiNetwork
, and make sure you know the password, orpsk
, for that network. You'll need it in a couple of steps. -
In the
wpa_cli
interactive prompt, run:> add_network
It should return a network number (should be
0
on a fresh Pi). That number is the index of the network that was added to the config file.0
is the first network,1
is the second, etc. Note that you CAN have multiple networks configured. You can repeat this process to add the network configuration for all the WiFi networks you want your Pi to attempt to connect to. It will connect to the first one it can, following the order they are defined. If you are running this for additional networks replace the "0
" in the commands that follow with the network index for the network you are configuring.0
Next, set the ssid/psk for your new network config. Replace the "
MyWiFiNetwork
" and "MyWiFiPassword
" with the appropriate values for your network SSID and password.Note: If the WiFi network you are connecting to is Open (doesn't require a password) rather than running
set_network 0 psk "MyWiFiPassword"
runset_network 0 key_mgmt=NONE
> set_network 0 ssid "MyWiFiNewtork" > set_network 0 psk "MyWiFiPassword"
Then, enable the network. It should immediately attempt to connect:
> enable_network 0
IMPORTANT!!!! Make sure to save the configuration:
> save_config
Then you can quit the
wpa_cli
interactive prompt with:quit
-
Verify the WiFi network configuration:
sudo cat /etc/wpa_supplicant/wpa_supplicant.conf
You should see output similar to the following:
ctrl_interface=DIR=/var/run/wpa_supplicant GROUP=netdev update_config=1 country=US network={ ssid="MyWiFiNetwork" psk="MyWiFiPassword" }
Or, if this was an open network that didn't require a password:
ctrl_interface=DIR=/var/run/wpa_supplicant GROUP=netdev update_config=1 country=US network={ ssid="MyWiFiNetwork" key_mgmt=NONE }
If you prefer to just manually edit the wpa_supplicant.conf
file, you can certainly do so. Just be careful to format it properly.
-
On the pi, open the
/etc/wpa_supplicant/wpa_supplicant.conf
file in a text editor (we'll use nano):sudo nano /etc/wpa_supplicant/wpa_supplicant.conf
-
Edit the contents of the file to meet your needs. Here is an example of a simple WiFI network that just needs an SSID and Password (psk). Verify the two letter country code is correct for your device, and replace the "
MyWiFiNetwork
" and "MyWiFiPassword
" with the appropriate values for your network SSID and password.ctrl_interface=DIR=/var/run/wpa_supplicant GROUP=netdev update_config=1 country=US network={ ssid="MyWiFiNetwork" psk="MyWiFiPassword" }
Or, if this was an open network that didn't require a password:
ctrl_interface=DIR=/var/run/wpa_supplicant GROUP=netdev update_config=1 country=US network={ ssid="MyWiFiNetwork" key_mgmt=NONE }
-
Save the changes to your file. In nano:
- Press
CTRL-X
to exit - Press
Y
to save. - Press
ENTER
to confirm the file name
- Press
-
Once you have configured your WiFi network using one of the methods above, you should reboot your pi. This will be necessary on Raspbian Stretch as it appears the WiFi network doesn't get enabled if it isn't configured on boot.
sudo reboot
-
Then login to your Raspberry Pi using the default credentials (or your custom credentials if you have changed them):
- Username:
pi
- Password:
raspberry
- Username:
-
Verify that your WiFi adapter got its IP Address:
ip -4 a
You should see output similar to the following, look for the IP Address of
wlan0
(or whatever interface you are interested in). For example, in the output below, thewlan0
interface's IPv4 address is192.168.2.24
with a24
bit subnet mask which really means it's subnet mas is255.255.255.0
.1: lo: <LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue state UNKNOWN group default qlen 1 inet 127.0.0.1/8 scope host lo valid_lft forever preferred_lft forever 3: wlan0: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc pfifo_fast state UP group default qlen 1000 inet 192.168.2.24/24 brd 192.168.2.255 scope global wlan0 valid_lft forever preferred_lft forever
-
Another way to look at your Pi's ip address is with:
ifconfig
The output is just a little noisier, but if you look under
wlan0
for theinet addr:
you should see the IP address for the WiFi network:eth0 Link encap:Ethernet HWaddr b8:27:eb:95:eb:21 inet6 addr: fe80::8c70:f7a7:6fbd:3a7/64 Scope:Link UP BROADCAST MULTICAST MTU:1500 Metric:1 RX packets:0 errors:0 dropped:0 overruns:0 frame:0 TX packets:0 errors:0 dropped:0 overruns:0 carrier:0 collisions:0 txqueuelen:1000 RX bytes:0 (0.0 B) TX bytes:0 (0.0 B) lo Link encap:Local Loopback inet addr:127.0.0.1 Mask:255.0.0.0 inet6 addr: ::1/128 Scope:Host UP LOOPBACK RUNNING MTU:65536 Metric:1 RX packets:261 errors:0 dropped:0 overruns:0 frame:0 TX packets:261 errors:0 dropped:0 overruns:0 carrier:0 collisions:0 txqueuelen:1 RX bytes:20300 (19.8 KiB) TX bytes:20300 (19.8 KiB) wlan0 Link encap:Ethernet HWaddr b8:27:eb:c0:be:74 inet addr:192.168.2.24 Bcast:192.168.2.255 Mask:255.255.255.0 inet6 addr: fe80::8a9:43db:3c5:50e1/64 Scope:Link UP BROADCAST RUNNING MULTICAST MTU:1500 Metric:1 RX packets:99134 errors:0 dropped:0 overruns:0 frame:0 TX packets:65765 errors:0 dropped:0 overruns:0 carrier:0 collisions:0 txqueuelen:1000 RX bytes:137469393 (131.1 MiB) TX bytes:12494038 (11.9 MiB)
-
Lastly, just FYI, you can also inspect your Pi's wireless network status with :
iwconfig
With output similar to the following:
lo no wireless extensions. wlan0 IEEE 802.11 ESSID:"MyWiFiNetwork" Mode:Managed Frequency:2.422 GHz Access Point: f4:xx:xx:xx:xx:a3 Bit Rate=7.2 Mb/s Tx-Power=31 dBm Retry short limit:7 RTS thr:off Fragment thr:off Power Management:on Link Quality=44/70 Signal level=-66 dBm Rx invalid nwid:0 Rx invalid crypt:0 Rx invalid frag:0 Tx excessive retries:176 Invalid misc:0 Missed beacon:0 eth0 no wireless extensions.
By default, your pi is named "raspberrypi". You will want to change that for each pi so you can easily refer to them on the network.
The Pi broadcasts is hostname as "<hostname>.local
" ("raspberrypi.local
" by default) using the "Multicast DNS (mDNS)" protocol. By giving each pi a unique hostname, you will be able to refer to them easily by name rather than their IP address on your local network (note, .local names ONLY work locally, on the same network)
There are two files where you need to update your hostname if you want to change it:
- `/etc/hostname` to set the name itself
- `/etc/hosts` to set the hostname for the local loopback address (`127.0.0.1`) so your pi can resolve its own name.
-
You can manually edit each of those files using
nano
:Start by editing
/etc/hostname
sudo nano /etc/hostname
Replace
raspberrypi
with your new desired hostname, and save the changes (CTRL-X
,Y
,ENTER
in nano):myhostname
Then edit
/etc/hosts
sudo nano /etc/hosts
Edit the
127.0.0.1
address (usually the last line) to point to your new hostname, and save your changes (CTRL-X
,Y
,ENTER
)127.0.0.1 localhost ::1 localhost ip6-localhost ip6-loopback ff02::1 ip6-allnodes ff02::2 ip6-allrouters 127.0.1.1 myhostname
-
Alternatively, you can use
raspi-config
to edit both of the files for you:sudo raspi-config nonint do_hostname "myhostname"
-
You should reboot your pi after giving it the new host name. Go ahead and do that and then log back in when it comes up:
Note: If you are still connected to the debug console via the USB to Serial cable, you don't need to re-connect. It should stay connected during the reboot. Cool! SSH or VNC connections however will need to be re-established when the Pi is done rebooting.
sudo reboot
-
Then the pi has rebooted, from your computer (ON THE SAME NETWORK AS THE PI), verify you can ping your pi using:
# Replace <hostname> with your Pi's hostname that you just set ping <hostname>.local # For example: ping myhostname.local #or # Replace <your.pis.ip.address> with your Pi's IP address ping <your.pis.ip.address> # For example, if the Pi's ip address is 192.168.2.24: ping 192.168.2.24
If you don't want to have to provide the Raspberry Pi's password everytime you ssh into the pi from a remote computer, you can configure ssh keys to automatically authenticate you.
-
On your computer (not on the pi), run the following command:
ssh-keygen -t rsa -C "SSH Key for logging into the pi"
-
Next, from your computer, ssh into the pi normally, using the "
pi
" username and password (password defaults toraspberry
). Reaplaceyour.pis.ip.address
below with the actual IP address for your pi (see above) or it's<hostname>.local
mDNS name (again, see above):# Replace <hostname> with your Pi's hostname that you just set ssh pi@<hostname>.local # For example: ssh pi@myhostname.local #or # Replace <your.pis.ip.address> with your Pi's IP address ssh pi@<your.pis.ip.address> # For example, if the Pi's ip address is 192.168.2.24: ssh pi@192.168.2.24
-
Now, in the ssh session on the Pi, run the following commands to create and configure the
.ssh
folder where the Pi's copy of your ssh keys will be stored:cd ~ install -d -m 700 ~/.ssh
-
Back on your computer, run the following command, entering the password for the "
pi
" user one last time:Note: This command uses cat to display the contents of the ssh public key (
~/.ssh/id_rsa.pub
) on your computer, it sends that output to an ssh session to your pi, and into a command that usescat
to pipe the incoming content into the.ssh/authorized_keys
file on the pi. Basically copying your ssh public key over to the list of authorized public keys on the pi.cat ~/.ssh/id_rsa.pub | ssh pi@your.pi.ip.address 'cat >> .ssh/authorized_keys'
-
Finally, on your computer, you should now be able to ssh into the pi without having to enter the password:
ssh pi@<hostname>.local #or ssh pi@<your.pis.ip.address>
Even through your pi is "headless" (meaning no monitor, keyboard, and mouse), you may still care about what display resolution the Pi is configured to use if you will be connecting through a graphical client like VNC.
The display configuration for your Pi is stored in the /boot/config.txt
file (or, more specifially, the config.txt
file on the boot
partition). You can learn more about the configuration options for the display from the VIDEO OPTIONS IN CONFIG.TXT document.
Basically though, you need to pick an hdmi_group
and an hdmi_mode
.
Those settings need to be written into the /boot/config.txt
file. You could do that manually, just find the existing entries and edit them, or you can use raspi-config
in either its interactive mode, or non-interactively from the command line.
The hdmi_group
can be one of three values:
hdmi_group | Result | Description |
---|---|---|
0 | Auto-detect from attached monitor's EDID | Won't work on a headless display because there is no monitor attached |
1 | CEA | Consumer Electronics Association, the standard typically used by TVs |
2 | DMT | Dipslay Monitor Timings, the standard typically used by monitors |
So you can see from above, we'll typically want to stick to hdmi_group
2
since we don't have anything attached, and we aren't using an old-school television as our display.
The hdmi_mode
value you select depends on what hdmi_group
you selected above. Since you can read all about it here, and we'll most likely be using hdmi_group
2
, I'll just list some likley hdmi_mode
selections for hdmi_group
2
. For more choices, refer to the docs:
HDMI_GROUP | HDMI_MODE | DESCRIPTION |
---|---|---|
2 | 39 | 1360x768, 60HZ |
2 | 82 | 1920x1080, 60HZ, 1080p |
2 | 85 | 1280x720, 60HZ, 720p |
-
On the pi, run:
sudo raspi-config
Then within the interactive raspi-config interface, select:
7 Advanced Options
A5 Resolution
- Select your desired resolution from the list, and press
ENTER
- Press
ENTER
to confirm - Use the
TAB
keys to highlightFinish
and pressENTER
- If you are ready to reboot now, select
Yes
and pressENTER
to reboot. Otherwise, selectNo
and pressENTER
. Just make sure to reboot later.
-
Run the following command replacing the
<hdmi_group>
and<hdmi_mode>
place holders with appropriate values from above:sudo raspi-config nonint do_resolution <hdmi_group> <hdmi_mode>
For example, to use
hdmi_group
2
(DMT) andhdmi_mode
82
(1920x1080)sudo raspi-config nonint do_resolution 2 82
When you are done, reboot the pi:
sudo reboot
If you want a more graphical remote connection to your Pi, you can use VNC.
-
Ensure that you enabled VNC on the Pi, if you haven't already done so. From the pi, run:
sudo rasp-config nonint do_vnc 0
-
Download a VNC Viewer Client application for your platform. I recommend Real VNC Viewer, but any client should work:
Download and install Real VNC Viewer
-
Use VNC Viewer to connect to your Raspberry Pi, specifying either the pi's IP address or .local to connect.
-
If you see a warning about SSH being enabled with the Pi's password still at default you can click "OK*" to clear it. However, you should consider changing your Pi user's password to help secure it.
-
If you are using the Real VNC Viewer, this is a toolbar that will appear if you move your mouse to the top center of the VNC display area. From there you can click buttons to control your VNC session including going Full-Screen. If you do go full screen and need to get out, again just move your mouse to the top center of the VNC display to re-access the toolbar:
Samba is the Service Message Block (SMB) and Common Internet File System (CIFS) protocol implementation for Linux/Unix. SMB/CIFS are the protocols used by Windows File Sharing. Basically that means that if we install Samba on the pi, we can configure it to host "shares" that we can connect to from Windows, or other computers that also have "Samba" installed.
The whole point here is to provide a convenient way to access the file system on the Pi as if it were a local drive on our development machine and allow us to edit files on the Pi as easily as we can edit local files.
-
First, in a terminal prompt on the Pi, update the
apt-get
list of packages:sudo apt-get update
-
Next, go ahead and upgrade any packages on your pi that are out of date (THIS MAY TAKE A WHILE TO COMPLETE. EVEN TEN MINUTES OR LONGER)
sudo apt-get -y upgrade
-
Now, you can install Samba. This could take a couple of minutes to complete:
sudo apt-get install -y samba samba-common-bin
-
Now that Samba is installed, we want to configure it. We'll start by renaming the original
/etc/samba/smb.conf
configuration file to/etc/samba/smb.conf.original
so we have it available if we need it back:sudo mv /etc/samba/smb.conf /etc/samba/smb.conf.original
-
Next, use
nano
to create a new empty/etc/samba/smb.conf
file:sudo nano /etc/samba/smb.conf
-
Copy the following contents (or you can copy them from the smb.conf file in this repo) in the new empy smb.conf file on the Pi. You should be able to copy the contents into your clipboard on your local computer, then past them into the nano editor in the pi terminal session Save the changes to the file (
CTRL-X
,Y
,ENTER
):Note: This config file creates a share named
root
that shares the/
path of the local file system. Only thepi
orroot
users can attach to the share though.[global] workgroup = WORKGROUP dns proxy = no log file = /var/log/samba/log.%m max log size = 1000 syslog = 0 panic action = /usr/share/samba/panic-action %d server role = standalone server passdb backend = tdbsam obey pam restrictions = yes unix password sync = yes passwd program = /usr/bin/passwd %u passwd chat = *Enter\snew\s*\spassword:* %n\n *Retype\snew\s*\spassword:* %n\n *password\supdated\ssuccessfully* . pam password change = yes map to guest = bad user usershare allow guests = yes [root] comment = root path=/ browseable=YES writeable=YES valid users= pi, root only guest=no create mask=0777 directory mask=07777 public=no force user = root
-
Next, back at the terminal prompt on the Pi, we need to set the Samba password for the
pi
user, run the following command and enter thepi
user names password twice. YOU SHOULD USE THE SAME PASSWORD YOU USE TO LOGIN TO THE DEVICE AS THEpi
USER:sudo smbpasswd -a pi
-
Back on your computer (assuming Windows here. for macOS users see How to connect with File Sharing on your Mac), open a NON-ADMINISTRATIVE command prompt (PowerShell or Command) and run the following command, again replacing "
your.pis.ip.address
" with your pis actual ip address , or "<hostname>.local
" hostname and typing in thepi
user's password when prompted:Note: The following command maps the "
P:
" drive letter on your Windows computer to the "root
" file share on the Pi. The "/PERSISTENT:YES
" keeps the drive mapping in place even if you logout and back in on Windows. You can specifiy a different drive letter than "P:
" if you wish.net use P: \\your.pi.ip.address\root /user:pi /persistent:yes
Git is the most popular source contgrol mechanism these days. To make sure you can easily work with git from the Pi:
-
Ensure that git is up to date on the pi by running the following on the pi:
sudo apt-get install git
-
Then configure your identity in git. Replace "
Your Name
" and "you@yourcompany.com
" with appropriate values:git config --global user.name "Your Name" git config --global user.email "you@yourcompany.com"
-
You can optionally configure git more as described in Getting Started - First-Time Git Setup
If you will NOT be using Node.js applications, skip this step. There is an older version of Node.js install on the Pi by default. Just leave it alone.
However, if you will be developing Node.js apps on your the pi, you should upgrade Node. to a later version.
-
You MAY need to install the Build tools before installing Node.js. Run the following on the Pi:
sudo apt-get install -y cmake build-essential curl libcurl4-openssl-dev libssl-dev uuid-dev python-dev python-smbus
-
To install Node 8.x run:
Note: See Debian and Ubuntu based Linux distributions for current install info.
curl -sL https://deb.nodesource.com/setup_8.x | sudo -E bash - sudo apt-get install -y nodejs
If you will be developing code on the Pi that communicates with Azure IoT Hubs:
Note: For more information, or for instructions on building the sdk manually, refer to the "Prepare your development environment" documentation for the Microsoft Azure IoT SDKs for Python repo.
The Raspbian image includes both Python 2.7 and Python 3.4 installations. You install the Azure IoT SDKs differently for each of them.
-
Upgrade pip to Version 9:
sudo pip install -U pip
-
Ensure that libboost is installed:
sudo apt-get install libboost1.55-all
-
Next install the Azure IoT Device SDK for Python using pip:
sudo pip install azure-iothub-device-client
-
Upgrade pip to Version 9:
sudo python3 -m pip install -U pip
-
Ensure that libboost is installed:
sudo apt-get install libboost1.55-all
-
Next install the Azure IoT Device SDK for Python using pip:
sudo python3 -m pip install azure-iothub-device-client
The following steps allow access to the peripherals on the pi (GPIO, I2C, SPI)
# Ensure SPI and I2C are enabled if you didn’t do so previously
sudo raspi-config nonint do_i2c 0
sudo raspi-config nonint do_spi 0
# Ensure you have the latest libraries installed
sudo apt-get update
sudo apt-get upgrade
sudo python -m pip install adafruit-gpio
sudo python3 -m pip install adafruit-gpio