Build a Raspberry Pi Webcam Server in Minutes

This tutorial will take you through how to set up a webcam server on the Raspberry Pi. You can have your very own Webcam visible on a web page.

Raspberry Pi Webcam Server

In this tutorial, we will be using a package called Motion. If you want to learn more about it, you can check out their website at Motion. This software will allow us to stream footage from a webcam connected to the Raspberry Pi. You will be able to view the stream via a web page in your favorite browser.

If you’re after more of a security-like system, check out the Raspberry Pi security camera tutorial as it features fully-fledged web streaming, motion detection, recording, and multi-camera functionality.

This tutorial is marked intermediate as it can be challenging to get it working, especially if you have hardware that differs to the versions used in this tutorial. If you can’t get this to work, the security camera solution linked above is much easier to get going.

Equipment

Below are some of the pieces of equipment that you will need to be able to complete this tutorial.

Optional

This tutorial was last tested on the Raspberry Pi 5 running the full version of Raspberry Pi OS Bookworm.

Setting up the Webcam Server on the Raspberry Pi

Firstly, we will need to install Raspberry Pi OS onto the Raspberry Pi. If you haven’t already done this, check out our guide on installing Raspberry Pi OS. It will take you through all the steps that you will need to do to get up and running.

1. We will be using the terminal, so open the terminal on the Pi or connect to it via SSH.

2. To begin, first, update the Raspberry Pi OS, so you’re running on the latest packages.

sudo apt update
sudo apt upgrade

3. Next, install the following packages. This command will work on the full and lite versions of Raspberry Pi OS.

sudo apt install autoconf automake build-essential pkgconf libtool git libzip-dev libjpeg-dev gettext libmicrohttpd-dev libavformat-dev libavcodec-dev libavutil-dev libswscale-dev libavdevice-dev default-libmysqlclient-dev libpq-dev libsqlite3-dev libwebp-dev libcamera-v4l2

4. Next, download the Motion deb file for Raspberry Pi OS from GitHub using the wget command and install it using the dpkg command. You can view all the releases for Motion over at their Github.

Run the two lines below to download and install Motion.

sudo wget https://github.com/Motion-Project/motion/releases/download/release-4.6.0/$(lsb_release -cs)_motion_4.6.0-1_$(dpkg --print-architecture).deb

sudo dpkg -i $(lsb_release -cs)_motion_4.6.0-1_$(dpkg --print-architecture).deb

That’s all you need to do before moving on to configuring Motion so that it will run on your Raspberry Pi.

Configuring Motion

1. We need to edit the configuration file, motion.conf. To do this, open the file in the nano text editor.

sudo nano /etc/motion/motion.conf

2. Find the following lines and ensure they are set to the values below.

  • daemon off
  • stream_localhost off

Note: Change the following two lines from on to off if you have issues with the stream freezing whenever motion occurs.

  • picture_output off
  • movie_output off

Optional (Don’t include the text after the #)

  • stream_maxrate 100 This change will allow for real-time streaming but requires more bandwidth and resources. It needs to be added to the config file. Default is 1
  • framerate 100 Changing this option will allow for 100 frames to be captured per second, allowing for smoother video. Default is 50
  • width 640 # This line changes the width of the image displayed. Default is 640
  • height 480 # This option changes the height of the image displayed. Default is 480

Altering these options can drastically affect the performance. You may need to tinker to get the best results.

3. Once done, save and exit by pressing CTRL + X then Y.

4. We need to enable the Motion service by running the command below.

This command will make Motion start when your Raspberry Pi powers on.

sudo systemctl enable motion

5. Ensure the camera is connected and run the following line.

sudo systemctl start motion

If you need to stop the service, run the following command.

sudo systemctl stop motion

6. You should be able to check out the webcam stream at the IP address of the Raspberry Pi. To get the IP address, use the hostname command.

hostname -I

7. In your browser, go to the IP address of your Raspberry Pi, followed by the port 8081.

192.168.1.121:8081

If you are using a Raspberry Pi camera, you will need to do a few extra steps, mentioned further down the page. You will see a grey box with an error if you do not do these steps.

8. If the web page isn’t loading, try restarting the service.

sudo systemctl restart motion

9. You should now have a fully working Raspberry Pi Webcam server that you can place wherever you would like (Given it is within Wi-Fi range) and be able to view the stream via the web browser.

If you want to allow external access to the camera, check out my instructions at the bottom of this tutorial.

raspberry pi USB webcam in action

Additional Steps for Using a Raspberry Pi Camera

If you want to use the Raspberry Pi camera module, you will need to do a few additional steps to set it up.

A Raspberry Pi 5 uses a different port, so you may need to acquire a ribbon cable (Amazon) designed to fit into the new ports.

1. First, go to the CSI (Camera Serial Interface) ribbon cable slot on the Pi and with two fingers on each side of the connector, pull up. This technique should now open the connector. This port is labeled CAM/DISP 0 on the Raspberry Pi 5.

2. Insert the ribbon cable with the metal leads facing away from the Ethernet Port. If you are using a Raspberry Pi 5, the metal leads must face toward the ethernet port.

3. Once you have lined it up, gently press the connector back down, and the cable will lock in place.

Clips and Ribbon Cable

4. Since the Raspberry Pi camera relies on a library called libcamera we will need to edit the service file. To do this, enter the following line.

sudo nano /lib/systemd/system/motion.service

5. In this file, find the line that contains the following text.

ExecStart=/usr/bin/motion

Update the line to the following text.

ExecStart=/usr/bin/libcamerify /usr/bin/motion

Once done, exit the file by pressing CRTL + X and then Y.

6. Since we just changed the source service file, we will need to reload the systemctl daemon. You can do this by running the following command.

sudo systemctl daemon-reload

7. Lastly, restart the motion service to ensure our changes have taken effect.

sudo systemctl restart motion

8. You should now be able to access the Raspberry Pi webcam stream by going to the Pi’s IP address on port 8081.

192.168.1.121:8081

You should now have a fully working Raspberry Pi camera server accessible within your local network. If you want to allow external access to the camera, please follow my instructions below.

Webcam Server Browser

Saving Motion Footage and Photos

By default, you will likely have permission problems when saving the photos and video triggered by motion. I go through the steps below on how to set this up to work correctly.

1. Firstly, let’s make a new directory for our photos and videos.

sudo mkdir /motion

2. Next, we need to change the group of the motion folder so motion can write into it. After that, we give the group; read, write, and execute permissions using the chmod command.

sudo chgrp motion /motion 
sudo chmod g+rwx /motion

3. We need to go back into the motion configuration file and change the target_dir to our new directory. First, open up the file with the nano text editor.

sudo nano /etc/motion/motion.conf

4. Update the target_dir line so it looks like the one below. Ensure you remove the ; from the start of the line.

target_dir /motion

5. Next, restart the motion service to load the configuration correctly.

sudo systemctl restart motion

6. When the camera detects motion, it will be saved into the specified folder. You can check this by running the following command.

ls /motion

Check out our Linux permissions guide for more information on setting permissions correctly.

Setting Up External Access

To enable external access to the Raspberry Pi webcam server, we will need to change some settings on the router. However, all routers are designed differently, so you may need to look up instructions for your router brand.

Please note that opening ports to the internet comes with a security risk. Please use strong security measures to prevent unauthorized access to your local network.

If you need a more in-depth guide, be sure to look at my guide on how to set up Raspberry Pi port forwarding and dynamic DNS.

If you’re unable to connect outside your local network, then you can try the following.

  • Check your router settings and confirm they are correct.
  • Check your IP hasn’t changed. Some internet service providers will provide you with a dynamic IP rather than a static IP. You can set up dynamic DNS to counter this.
  • Ensure that the port mapping matches correctly with the motion port. For example, the internal port must be set to 8081.
  • Restart the router.

Conclusion

I hope you enjoyed this tutorial on how to build a Raspberry Pi webcam server. You should now be able to view your camera stream using a web browser.

If you want more projects, please check out all our Raspberry Pi projects. We are always working on more, so be sure to check back in the future or stay up to date by signing up to our newsletter.

Please feel free to use the comment section below to provide feedback for this tutorial.

Leave a Reply

Your email address will not be published. Required fields are marked *

303 Comments

  1. Avatar for Bruce Moore
    Bruce Moore on

    Nice writeup, but… It did not work on for Bookworm lite on a Zero2W. libcamerify was no loaded as part of the OS or lib installs. I had to go to the full version to get it to work.

  2. Avatar for ITCarGuy
    ITCarGuy on

    I’ve used this numerous times with a Pi Zero and USB cams and once with a Pi Cam module v2…and it is AWESOME!!! That said, should I expect it to work with a Pi 5/Bookworm/Pi cam module v3 wide? I only get “UNABLE TO OPEN VIDEO DEVICE” when I open the web page locally. Curious if anyone has it working with a Pi 5 and v3 module? Thanks!

    1. Avatar for Gus
      Gus on
      Editor

      We updated the tutorial, so it should work on the Raspberry Pi 5/Bookworm. You will need to make use of libcamerify to get it to work.

  3. Avatar for John Jennings
    John Jennings on

    Really excellent guide. Thanks.

  4. Avatar for armen
    armen on

    Thanks for this guide. I’ve used it successfully a few times now.

  5. Avatar for Raymond Stewart
    Raymond Stewart on

    I am getting a string of broken dependencies. Motion cannot install. Raspian 9.11 stretch.

  6. Avatar for Gregor
    Gregor on

    Hi, I tried that. Everything works fine although at the beginning I faced the trouble with the dependencies… just go again to the update or try “sudo apt –fix-broken install”. However, the view is upside down. Any idea how to flip it?

    1. Avatar for Gregor
      Gregor on

      never mind, I’ve got it 🙂
      in motion.conf add “rotate 180”

  7. Avatar for Garth
    Garth on

    Thanks for the previous response, new question. I’m having issues downloading some of the dependant packages. Example is it says: Unable to locate package libmariab3. There are a few other packages it could not locate.

    1. Avatar for Emmet
      Emmet on
      Editor

      Hi Garth,

      I just tried on a fresh installation of Raspbian Buster and all the packages installed successfully.

      Try running sudo apt update again before installing the packages.

      Cheers,
      Emmet

    2. Avatar for Garth
      Garth on

      I figured it out that the mirror repository that I was downloading packages from was down so I changed the repository I was downloading from. Thanks.

    3. Avatar for Mike Sims
      Mike Sims on

      I was having the same issue even after running all of the updates, so what I did was I first purged the failed install attempt:

      *sudo dpkg -P motion*

      Then I just did a full install of whatever the most recent version, which will also make sure that all of the dependencies are installed. HOWEVER, when you do this, note that the settings in the file motion.conf will not match these instructions exactly. For example, *picture_output* is now *output_picture* … so I recommend just going through the config file and change the settings that make sense for your desired config. In my case, I just needed to stream my logitech USB cam over the local network, so I turned off *stream_localhost*, increased the streaming framerate to 50 and I changed the image size to 640×480. I’m only using this to monitor my 3D printer during print jobs.

      Here is the command to do a full clean install of the most recent version:

      *sudo apt-get install motion*

      Good Luck!

  8. Avatar for Garth
    Garth on

    Hi do you know if this will work for raspbian jessie or will I have to upgrade to buster?

    1. Avatar for Emmet
      Emmet on
      Editor

      Hi Garth,

      To use the latest version of the motion server software you will need to be running Raspbian Buster.

      Cheers,
      Emmet

  9. Avatar for Jim
    Jim on

    On 11-22-2019 I used this page to set up motion on Pi3b.

    “For this tutorial, we will be installing Motion for Raspbian Stretch.
    If you’re not already on it then I highly recommend that you upgrade.”
    <<<< I loaded stretch on card.

    Step 3 shows command for Buster but not for stretch Raspbian Buster.

    sudo apt install autoconf automake build-essential pkgconf libtool git libzip-dev libjpeg-dev gettext libmicrohttpd-dev
    libavformat-dev libavcodec-dev libavutil-dev libswscale-dev libavdevice-dev default-libmysqlclient-dev libpq-dev
    libsqlite3-dev libwebp-dev " <<<< this command fails and I cannot find what will work with stretch

    I loaded SD with stretch and did update and upgrade (long time). Since I couldn't for command for stretch I used
    the buster command above. Failed. Should I just reload card with buster?

    [SNIP, PACKAGES NOT FOUND, SNIP]

    1. Avatar for Emmet
      Emmet on
      Editor

      Hi Jim,

      Sorry about that, the tutorial should of been updated to mention that we are installing Motion for Raspbian Buster isntead of Stretch.

      I have now corrected this.

      We recommend upgrading your Raspbian image to Buster then trying the tutorial again.

      Cheers,
      Emmet

  10. Avatar for Branson
    Branson on

    How to make it run script on startup? Would adding service motion start to the end of /etc/rc.local work?

    1. Avatar for Emmet
      Emmet on
      Editor

      Hi Branson,

      Try running the following command.

      sudo systemctl enable motion

      This command should allow the service manager to handle it automatically for you.

      Cheers,
      Emmet

  11. Avatar for Aron Kertesz
    Aron Kertesz on

    Hi,

    I just got a new Pi4b and tried to go through the installation. It has Raspbian GNU/Linux 10 (buster) and it complains that the libmariadbclient18 cannot be found and installed.
    Now, I have an older Pi3 with Raspbian GNU/Linux 8 (jessie) and there it seems to work.
    Is this a release issue? Some incompatibility? Should I try to install Jessie on the new one as well?

    thanks,

    aron

    1. Avatar for Emmet
      Emmet on
      Editor

      Hi Aron,

      I took a quick look into this and it looks like some of the packages changed in Debian Buster.

      We have updated the package list so it should now work fine.

      The updated command is the following one.

      sudo apt install autoconf automake build-essential pkgconf libtool git libzip-dev libjpeg-dev gettext libmicrohttpd-dev libavformat-dev libavcodec-dev libavutil-dev libswscale-dev libavdevice-dev default-libmysqlclient-dev libpq-dev libsqlite3-dev libwebp-dev

      Cheers,
      Emmet

    2. Avatar for Aron Kertesz
      Aron Kertesz on

      Thanks a lot! I will check it now.

  12. Avatar for John Tempest
    John Tempest on

    cheers Emmet I will try that

  13. Avatar for John Tempest
    John Tempest on

    I am now using raspbian Buster. Do I just alter the stretch to Buster in
    “sudo dpkg -i pi_stretch_motion_4.2.1-1_armhf.deb”

    1. Avatar for Emmet
      Emmet on
      Editor

      Hi John,

      We have gone ahead and updated the tutorial so that it points to the new buster version of Motion.

      You should be able to run the following two commands.

      sudo wget https://github.com/Motion-Project/motion/releases/download/release-4.2.2/pi_buster_motion_4.2.2-1_armhf.deb
      sudo dpkg -i pi_buster_motion_4.2.2-1_armhf.deb

      Cheers,
      Emmet