Every time you reboot your Raspberry Pi it contends on the WiFi network for a new IP ("internet protocol") address. It may get the same address as last time, it may not. There is a way to have it always get the same
address, called a __static IP address__. 

You don't need to use a static IP address (the router automatically assigns addresses when asked to, and this all works fine) but it's handy if you want to remotely connect to your robot using ssh so that you won't have to somehow find out which IP address the robot is currently using. 

The idea here is to find out what address your robot is currently using, assume that address is generally available, and then set it so the robot always asks for the same address. The only downside is that if another device shows up on your network and dynamically obtains that address, your robot won't be able to connect to the network because the address is in use — every device on a network must use a unique address.

! How to Disable ipv6 on a Pi

When viewing the results from typing {{ifconfig}} you see only "inet6" output and no "inet" then ipv6 has been enabled. If you want to use ipv4 style IP addresses (e.g., 192.168.1.85) then you'll need to disable ipv6.

If you're using Raspbian (i.e., earlier versions of the Raspberry Pi operating system), add the following to the end of the single line of text in the file /boot/cmdline.txt: 
{{{
ipv6.disable=1
}}}
This has the advantage that you can edit it by mounting it to your desktop before you boot the Pi, since the boot partition is readable under desktop operating systems. ([source|https://www.raspberrypi.org/forums/viewtopic.php?t=256349#p1563399])

If you're using the current "Raspberry Pi OS" then edit/create the file {{/etc/modprobe.d/ipv6.conf}} to either contain the following single line, otherwise add to the existing file the line :
{{{
blacklist ipv6
}}}
Then reboot. 


! How to Find Out What Address Your Robot Is Using

First, let's see what address it currently has. Type the {{ifconfig}} command and then hit __Enter__:
{{{
  % ifconfig
}}}
The result will be a lot of stuff, most of which you can avoid. It comes in sections, one of which
will be named {{wlan0}} or something similar (with "''wlan''" meaning "wireless local area network").

In that section there's one string of characters you're looking for, what follows "inet" on the second line of that section:
%%(font-family: 'Source Code Pro', monospace; font-size:smaller; white-space: pre;)
  wlan0: flags=4163<UP,BROADCAST,RUNNING,MULTICAST>  mtu 1500
          __inet 192.168.1.74__  netmask 255.255.255.0  broadcast 192.168.1.255
          inet6 fe80::6829:3b23:1365:745  prefixlen 64  scopeid 0x20<link>
          inet6 fd48:3c0c:41c9:3100:b1b7:99fc:7136:b0f3  prefixlen 64  scopeid 0x0<global>
          ether 16:8b:34:0e:08:6f  txqueuelen 1000  (Ethernet)
          RX packets 14174  bytes 1782568 (1.6 MiB)
          RX errors 0  dropped 0  overruns 0  frame 0
          TX packets 8959  bytes 2536988 (2.4 MiB)
          TX errors 0  dropped 0 overruns 0  carrier 0  collisions 0
        
%%


The "192.168.1.74" above (four numbers separated by dots) is the IP address of the robot. Yours will likely start with the same first three "192.168.1" (this is common on local area networks at home but not always true), with the last number "74" being unique to your robot.

! How To Set a Static IP Address

__NOTE:__ this currently doesn't seem to work on a Raspberry Pi 4 due to ipv6 (?), but has worked reliably for the Raspberry Pi 3 B+.

The DHCP service must be running on your Pi. To check, try this:
{{{
sudo service dhcpcd status
}}}

If it's not running you can start it (and with the second line, set it to always start) with:
{{{
sudo service dhcpcd start
sudo systemctl enable dhcpcd
}}}

Then, edit the DHCP configuration file located at {{/etc/dhcpcd.conf}}. You'll need to do this as a superuser (because you need special permissions to edit system configuration files), so use "sudo" and the "nano" editor like this:
{{{
  % sudo nano /etc/dhcpcd.conf
}}}

...and add these lines at the bottom of the file (subsituting your chosen IP address for the "192.168.1.74"):

%%(font-family: 'Source Code Pro', monospace; font-size:smaller; white-space: pre;)
  # set a static IP address for this Pi
  interface wlan0
  static ip_address=__192.168.1.74__/24
  static routers=192.168.1.254
  static domain_name_servers=192.168.1.254
  
%%



! References

This information is derived from from pages like:

* [How to set a Raspberry Pi with a static ip address?|https://www.ionos.com/digitalguide/server/configuration/provide-raspberry-pi-with-a-static-ip-address/]
* [Setting up Raspberry Pi WiFi with Static IP on Raspbian Stretch Lite|https://electrondust.com/2017/11/25/setting-raspberry-pi-wifi-static-ip-raspbian-stretch-lite/]

...where there's a lot more detail than here if you get stuck. If you mess things up just comment out the lines you added by putting a "{{#}}" at the beginning of those lines.


----

[{Tag Recipe}]