Why? I want to set up a computer on my home network dedicated to running code. You may want to do this if:
- You want to run code that takes a long time to complete. Let it run on the server computer so you can use your main computer for other things.
- Your main computer is low on hard drive space. Upload all the data files to the server and run your analysis on the server.
Who? Programmers comfortable with Linux who need to run code on a separate computer they don't mind reformatting. You don't need to be an expert Linux user. "Comfortable with Linux" can just mean comfortable searching the internet to find out what to type into a terminal. DON'T do this on your main computer. This will completely erase and rewrite the hard drive.
What? Ubuntu server 22.04 LTS with Ubuntu desktop, RStudio server and R 4.3 (or the latest versions)
Cost? All the software is free. For hardware, you need the following:
- "Main" computer
- To download files, prepare the USB drives, check that the server works, and search the internet for help
- I used my regular personal computer
- Second computer to become the server - this will be erased/overwritten
- Save anything you want to keep somewhere else, including data and software licenses. Everything will be erased during the setup process.
- I used an old desktop computer. They sell special server computers (more expensive due to faster processors and better RAM), but I strongly suggest using an old desktop you already have for a first time project.
- Empty USB drive
- This will be erased/overwritten to make bootable USB drives to erase & install things on the server computer
- Afterward, you can reformat back to a regular USB drive for file storage
- The storage amount is dictated by the .iso file you are installing:
- 4 GB is ok for Ubuntu server
- 8 GB is needed for Ubuntu desktop since it has more software
- Ethernet cable and wired access to the internet for the server (at least for the setup steps)
- Keyboard, mouse, and monitor (only necessary for setup)
- Directly connect your regular keyboard, mouse, and monitor to avoid buying more. This can be temporary just for setup steps.
- Alternatively: I used a Linux-compatible USB switch and cheap no brand VGA switch so I could use the same keyboard, mouse, and monitor for both my Window and Linux server computers.
- Alternatively 2: You can also use a tiny $9 keyboard+touchpad combo for the server computer. I tried this but didn't like it long-term because it is too small and uncomfortably slow to use.
How?
Table of contents
- Prepare an executable USB drive to install the Ubuntu server
- Install the server or desktop
- Pick one depending on how you started:
- After Ubuntu Server --> Set up a desktop (GUI) for the server - optional but more user friendly
- After Ubuntu Desktop --> Install OpenSSH server
- Add new users
- Add security to the server (ufw firewall)
- Make your home server private, only available from your home internet network
- Set up a static IP address for the server computer
- Log into the server via ssh from the main computer
- Troubleshoot ssh issues
- Install R 4.4 or later (6/2024 update)
- Install RStudio server (6/2024 update)
- Install Perl, Python, and JupyterLab
- Install Dropbox
- Make your whole hard drive space available (8/2021 update)
- Install a remote desktop server
- Install a network printer using an IP address (Brother printer)
- Suggested software
- Expanded security maintenance
- General maintenance
- Good luck! Words of encouragement
- If you get stuck after a terminal command, use Ctrl+Z
Prepare an executable USB drive to install the Ubuntu server or desktop
- Detailed instructions with screenshots [WikiHow]
- Download an .iso file of the Ubuntu server or desktop, e.g. Ubuntu Server 22.04.3 LTS
- Select "Option 2: Manual install"
- Download the .iso file anywhere (main computer or USB flash drive ok)
- LTS = long-term support, good so you don't need to upgrade as often
- .iso files are packaged files that can be used to make installation CD-ROMs or executable USB drive
- You can start with either server or desktop, then install the other later
- Get a >4 GB USB drive that you're ok erasing completely. This will become the executable USB.
- If you downloaded the .iso file to a USB flash drive, then you need a second USB flash drive that you are ok erasing. You can't use the same USB flash drive.
- First USB=storage of the downloaded .iso file, does not need to be erased.
- Second USB=to be erased and rewritten with the .iso file contents.
- Using Rufus (freeware), the .iso file, and your USB drive that you are ok erasing completely, make an executable USB drive to install the Ubuntu server.
- Run Rufus on your main computer, with your USB drive plugged in
- Install the .iso file onto the USB that you want to make executable. Use default settings, plus one addition from advanced settings: check the box for "Add fixes for old BIOSes (extra partition, align, etc.)"
- If Rufus says your .iso file needs a different Grub and asks if it can download it for you, say yes and continue.
- The final executable USB can used during computer start up to run the .iso data, but is safe to plug into a computer that is already turned on (won't run the .iso data).
Image shows installation of Ubuntu Studio, not Ubuntu server, but it's very similar. "Device" is your USB drive. Use "Select" to load your ISO file. |
Install the server or desktop
- Use an old desktop that you are ok erasing completely
- Beware: you shouldn't have any files or software you want to keep on it!
- You will lose the Windows or iOS operating systems, too!
- Optional (recommended if donating the computer): erase the hard drive with DBAN software
- Download the DBAN .iso file (free) and create an executable USB drive using Rufus
- Optional step because installing the Ubuntu server overwrites the hard drive anyway
- But using DBAN overwrites the hard drive several times and ensures your original data can't be recovered
- Reboot the computer
- Disable "fast restart" if you have Windows 8 or later
- Starting with Windows 8, computers have a "fast restart" mode that skips your opportunity to enter the BIOS menu when you start it again.
- Enter the BIOS menu by holding down the F2 or F12 key as soon as you press the power button. Keep holding it for several seconds until the BIOS menu appears.
- Search the internet for your computer's instructions. It might be the F1 key or another key.
- May require rebooting the computer several times to get it right
- If you see the Windows screen, shut down and try again
- Timing is key! Your opportunity to enter the BIOS is a really short window at the very beginning of start up
- Edit the BIOS settings to boot from USB first, before booting from the hard drive
- Turn off BIOS safety settings that prevent booting from USB, if any
- Turn off Windows secure boot
- Change the boot order to boot from USB before anything else (hard drive, CD, etc)
- Usually this is the most difficult part because it is very computer-specific
- Don't quit at this step! The rest is easier!
- Shut down the computer completely after adjusting BIOS settings
- Connect the computer to the internet before the Ubuntu setup process
- Strongly suggested: connect to ethernet using a cable. It is much easier! You can setup wifi later after you install a desktop.
- Not recommended: you can connect to wifi from the command line, but it's a pain. Tips if you try this:
- Check your IP address with: ip a
- When editing YAML, use two spaces, not tabs for indentation.
- Plug in the executable USB drive that you created with Rufus and the Ubuntu server .iso installation file
- Turn on the computer
- It should boot from the USB and start the Ubuntu server installation.
- If not, try holding F2 or F12 when turning on the computer. You may need to adjust more BIOS settings until it works.
- Follow installation instructions. The first few minutes are just waiting for the screen of automatic tasks to complete. Eventually you get a text screen that says welcome.
- For Ubuntu Server: here is what I selected. [x] means I checked that box:
- Language: [x] English
- Choose type of install: [x] Ubuntu server, [x] Search for additional third party drivers
- Network connections: Connect to ethernet "eth" (preferred)
- [x] Use entire disk, [x] set disk up at LVM group
- Accept default storage configurations
- Select a username and server name (make each one word, no spaces)
- [x] Install OpenSSH
- Featured server snaps: keep all default
- For Ubuntu Desktop: I accepted all defaults
- Remove the executable USB drive once the installation is complete.
- If you don't, the computer will restart and boot from the USB again. You will get a message to "remove installation media" (remove the USB). Do so and hit [Enter] to continue.
- Keep the installation drive nearby until you finish and everything works. If something goes wrong, you can re-install.
- After all is done, you can reformat (erase) the executable USB with your main computer to use it like a normal USB storage drive again.
- It is safe to plug in when the computer is already turned on. It was created to execute on start up and will not execute when you plug it in any other time.
- Just in case, if your main computer is confused and asks if you want to import contents or run the ISO, click "Cancel" or "No". If your main computer asks if you want to reformat the USB drive, say "OK" or "Yes".
If you started with Ubuntu Server:
Set up a desktop (GUI) for the server
- By default, the Ubuntu server just has the command line interface. Set up a desktop to make life easier. This requires internet so make sure your ethernet cord is connected.
- Install tasksel, then open it to see what it can install. Check boxes with the [spacebar] and move to "OK" using the [tab] key. Use Ctrl+Z to exit tasksel.
- sudo apt update
- sudo apt upgrade
- sudo apt-get install tasksel
- tasksel
- Install a GUI (a desktop style) from the command line using tasksel or the default apt get method. You only need one GUI.
- Ubuntu Studio desktop is nice if hard drive space isn't an issue. It comes with audio, video, and graphical editing software. Good if you want to use the server computer as an extra desktop.
- sudo tasksel install ubuntustudio-desktop
- During the installation of jackd2 (an audio server installed with Ubuntu Studio), you will get this message: "Enable realtime process priority?" I said no.
- MATE desktop is fine also. It comes with useful software and takes up less space than Ubuntu Studio. (Don't run both, pick one):
- sudo tasksel install ubuntu-mate
- sudo apt install ubuntu-mate-desktop
- MATE core desktop is a barebones version of MATE. Useful if you want to save hard drive space and only use the computer as a server. It works for that, but I hated it whenever I had to log into the server computer. For notekeeping purposes only, this is the command for it:
- sudo tasksel install ubuntu-mate-core
- Lubuntu desktop is
the lightest desktop (smallest file size). When I installed it, I lost
access to the terminal window via the GUI or keyboard shortcuts. I had
to reinstall the server using the executable USB drive. Not recommended!
- Select and install a display manager (pick one) that works with the GUI you want:
- sudo apt install lightdm # lightweight, default for Ubuntu 22.04 LTS with Ubuntu Studio
- sudo apt install gdm3 # heavier, default for Ubuntu 22.04 LTS with MATE
- sudo apt install slim -y # lightweight, recommended for Ubuntu 24.04 LTS
- Enter the GUI and celebrate when the all text terminal turns into a colorful desktop with ONE of the following commands to start the desktop software (don't run all, pick one):
- sudo service lightdm start
- sudo service gdm3 start
- sudo service slim start
- Log in with your username and password, then check the desktop environment.
- Make sure you can open a terminal window
- Make sure you can access the internet.
- Connect to wifi at this point if desired.
- If your password doesn't work, check if it works in the terminal:
- Ctrl + Alt + F1
- Ctrl + Alt + F2
- Try either one. To go back to the GUI, try either one again.
- Prevent the server from going to sleep with this sequence (not a terminal command)
- Settings > Power > Automatic Suspend > Off
- This keeps the server accessible
- Make a file of system specifications
- sudo lshw -html > server_specs.html
- This creates an .html file with information on your hard drive, memory, graphics and sound cards, wifi card, etc.
- Exit the GUI (not recommended unless you're replacing it). This removes the desktop and takes you back to a terminal only interface. You don't need to do this to access the terminal. This is just for reference:
- sudo service <DisplayManager> stop
- where <DisplayManager> is either lightdm or gdm3 or slim
If you started with Ubuntu Desktop:
Install OpenSSH
Add security to the server (ufw firewall)
- https://www.howtoforge.com/tutorial/openssh-security-best-practices/
- https://phoenixnap.com/kb/linux-ssh-security
- https://linux-audit.com/ubuntu-server-hardening-guide-quick-and-secure/
- https://serverfault.com/questions/157375/reject-vs-drop-when-using-iptables
- https://www.thegeekstuff.com/2011/05/openssh-options/
- https://ubuntu.com/server/docs/security-users
- https://help.ubuntu.com/community/IptablesHowTo
ssh -V
sudo nano /etc/ssh/sshd_config
- Find the line that says "#Port 22".
- Remove the hashtag and change the number to something other than 22.
- Don't use these ports for ssh. They are used for something else already:
- 20 (ftp-data)
- 21 (ftp server)
- 22 (default ssh port, often targeted by bots and hackers)
- 23 (telnet server)
- 25 (email server)
- 53 (DNS server port for rerouting internet traffic)
- 69 (tftp server)
- 80 (internet http port)
- 110 (POP3 server)
- 123 (NTP server)
- 443 (internet https port)
- 8787 (RStudio server port)
- 8888 (Jupyterlab server port)
- To save changes: Ctrl+O
- To exit the text editor: Ctrl+X
sudo systemctl reload ssh
sudo systemctl status ssh
If the status message still says that the server is listening on the default port, port 22, then stop and restart the ssh server a different way:
sudo systemctl start ssh
sudo systemctl status ssh
You should see that the server is listening on your desired port now.
Enable the firewall and allow traffic through specific ports:
sudo ufw enable #turns on the firewall
sudo ufw allow www #allow internet access
sudo ufw allow 53/tcp #allow DNS queries to route internet traffic
sudo ufw allow 80/tcp #allows http access
sudo ufw allow 443/tcp #allows https access
sudo ufw allow 8787/tcp #RStudio server port
Open up the port you are using for ssh access, but only allow access from your local home network IP addresses. Example with port 25:
sudo ufw allow from 192.168.0.0/24 to any port 22
sudo ufw allow from 192.168.1.0/24 to any port 22
Replace "22" with whichever port you are using for ssh access. The default port is 22.
Replace the IP address with your home network range if needed, though 192.168.0.x and 192.168.1.x are common patterns. This is not the same as your public IP address visible to people on the internet. The "/24" at the end is the same as saying the last number can vary.
DON'T do the "ufw allow from" version of the terminal command for the internet ports or you may lose internet access.
Reload the firewall to apply the rules:
sudo ufw reload #apply the rules
View which ports are open:
sudo ufw status verbose #more detailssudo ufw status numbered #supplies a numbered list
Delete any rules you don't want using the line <number> (without the greater/less than signs):
sudo ufw delete <number>
I suggest deleting any lines for port 22, which may have been opened automatically if at any point you ran "sudo ufw enable ssh".
To delete all ufw rules and start over:
sudo ufw reset
sudo ufw enable #turns on the firewall again
Also recommended is the package "fail2ban" which automatically blocks IP addresses that try to brute force login into your server with multiple attempts. After a certain number of failed attempts, fail2ban prevents further tries.
sudo apt install fail2ban
systemctl status fail2ban.service # check status info. It will be inactive by default. Ctrl+Z to return to terminal.
Read the configuration instructions before enabling it.
Set up a static IP address for the server computer
- Local IP address
- assigned by your internet router to everything that connects to it,
usually starts with 192.168.0.x, or 192.168.1.x, where the number x
varies. This local address changes as things get disconnected and
re-connected, but you can reserve specific local IP addresses for
specific equipment MAC addresses for free.
- Public IP address - assigned by your internet service provider, find yours at whatismyIP.com. This is what websites see when you visit them. Unless you pay for premium internet service, your public IP is not static.
- Identify the MAC addresses for the Ubuntu server computer with this terminal command:
- ip a
- MAC addresses look like letter and number pairs in this format, A0:A0:A0:A0:A0:A0
- Ethernet and wifi have different MAC addresses
- Write down both and then see which one is connected to the internet router
- Log into your internet router's admin website to set up a static IP address ("reserve an IP address") for the Ubuntu server
- This requires administrative access to the internet router. Ask whoever set up the internet for help, or check the back of your internet router for default login information.
- Here are default router addresses, usernames, and passwords
- Instructions to reserve IP addresses vary by manufacturer
- Search "how to reserve IP address printer __[your router model]__" and follow those instructions for the Ubuntu server instead. Printers are the most common equipment that needs a static IP, so printers will have the most help pages on this topic.
- Check under "LAN Setup" and find a section called "Address Reservation"
Log into the server via ssh from the main computer
- On the server computer, turn on ssh access and check ssh server status (should be active)
- sudo systemctl start ssh
- sudo systemctl status ssh
- Cntr+Z to quit the status window
- On the server computer, ssh into the "localhost" (not an IP address, do not replace) and then exit
- ssh localhost -p <port>
- Where <port> is replaced by your ssh port, default is 22
- Say "yes" when asked if you want to add the localhost to a list of known hosts
- exit
- On the main computer, open a terminal.
- On Windows, you can open a terminal like this:
- WindowsKey + R, then type "cmd"
- Or search "cmd" and click Command Prompt
- Alternatively, use MobaXterm software (free version) or PuTTY (freeware) to interact with the server.
- On the main computer, open a terminal and type something like:
- ssh user@192.168.0.10
- Replace "user" with your server username
- Replace "192.168.0.10" with your specific Ubuntu server's local static IP address
- This example assumes the default ssh port (port 22).
- ssh user@192.168.0.10 -p <port>
- Where <port> is your ssh port number. See the section on increasing server security by changing the ssh port number.
- If using MobaXterm or PuTTY, fill in the boxes for username, IP, and port number.
- First time message will look something like this: "The authenticity of host '[192.168.0.10]:22 ([192.168.0.10]:22)' can't be established. ECDSA key fingerprint is...."
- Say "yes", you want to continue connecting.
- The terminal should ask for server login information
- SECURITY NOTE: the server does not yet have a firewall installed. I suggest continuing with defaults and checking that everything works before enabling the firewall (instructions for that are at the end).
- If you are taking a break, you can turn off the ssh server with this:
- sudo systemctl stop ssh
- Then turn it back on when you come back:
- sudo systemctl start ssh
- Or just turn off the server computer until you are ready to add additional security
Troubleshoot ssh issues
- https://likegeeks.com/ssh-connection-refused/
- https://www.webservertalk.com/troubleshoot-ssh-connection-refused
- https://ubuntu.com/server/docs/service-openssh
- Check the server IP address to verify that you are attempting to ssh to the correct IP
- ip route
- Check that the server computer has internet access at all
- ping 8.8.8.8 -c2
- This sends two packets to check for a connection. Note: there is no space between c and 2
- Check for 0% packet loss which means the internet works
- If there is packet loss, then troubleshoot your internet connection
- Check that the server computer DNS is rerouting internet traffic correctly
- ping google.com -c2
- Check for 0% packet loss which means the DNS is working correctly AND you have internet
- If the ping to 8.8.8.8 works, but the ping to google.com fails, then you have a DNS resolution error. This happened to me after rebooting my original Ubuntu server 20.04 LTS computer and I ended up reinstalling the whole server because nothing seemed to fix it. If it happens to you, try rebooting the internet router! I did not try that.
- If you have a firewall enabled on the server computer (instructions for that later), make sure you opened the ssh port.
- sudo ufw allow ssh #enables default port 22
- sudo ufw allow 25/tcp #where 25 should be replaced with whatever port you are using for ssh if not the default port 22
- Disable the server firewall if enabled - does that allow you to ssh into the server computer? If so, you will need to edit the firewall rules.
- sudo ufw disable
- Check that your main computer's firewall allows internet access to whatever program you are using to ssh into the server, examples:
- Windows command prompt (cmd.exe)
- Windows Subsystem Linux (wsl.exe)
- PuTTY - a free ssh client that you may want to try if the Windows command prompt isn't working and you don't have Windows Subsystem Linux
- Create a second server account with less privileges and attempt to ssh from that account
- otheruser@serverIP #assumes default port 22
- otheruser@serverIP -p 25 #tries port 25 (replace "25" with your ssh port number)
- Remove OpenSSH and reinstall. Don't type the #comments
- sudo apt-get purge openssh-server
- sudo apt-get autoremove #cleans up dependencies not used by anything else
- sudo apt-get autoclean #cleans up more leftover files
- sudo apt-get update
- sudo apt-get upgrade
- sudp apt install openssh-server #reinstall
- sudo systemctl start ssh #start the ssh server
- sudo systemctl status ssh #check status
- If using your main account, try permitting root login temporarily. Not recommended as a long-term solution since it makes the server less secure.
- sudo nano /etc/ssh/sshd_config
- Type this line without any hashtag (#) in front:
- PermitRootLogin yes
- [Ctrl+O], [Ctlr+X] to save and exit
- sudo systemctl restart ssh
- Set up a firewall rule limiting IP addresses to the ssh port if you want to keep this setting.
- Reboot the internet router if nothing else works. When I had ssh issues, rebooting the internet router fixed these error messages:
- "Resource temporarily unavailable" from Windows Subsystem Linux
- "Connection timed out" from Windows 10 command prompt
Install R 4.4 or later (6/2024 update)
sudo apt-get purge r-base* r-recommended r-cran-* #remove old pre-installed R version
sudo apt autoremove #remove dependencies not used by anything else
Install latest R version
Don't
skip installing the development packages. If you only install r-base,
you will have problems with missing dependencies when you try installing
R packages in the future.
sudo apt update
wget -qO- https://cloud.r-project.org/bin/linux/ubuntu/marutter_pubkey.asc | sudo tee -a /etc/apt/trusted.gpg.d/cran_ubuntu_key.asc # the qO has a capital letter O not number 0
sudo add-apt-repository "deb https://cloud.r-project.org/bin/linux/ubuntu $(lsb_release -cs)-cran40/"
This step tell Ubuntu where to download the newest R version.Note, "focal" is for Ubuntu 20.x versions, "jammy" is for Ubuntu 22.x versions, but you may need a different version.
Using $(lsb_release -cs) automatically selects the correct release name.
sudo apt install r-base r-base-core r-recommended r-base-dev #install R
sudo apt install libxml2-dev libcurl4-gnutls-dev libssl-dev cmake #development packages
sudo apt install libcurl4-openssl-dev4 libharfbuzz-dev libfribidi-dev ## optional, required for tidyverse R packages
sudo apt install libmagick++-dev ## optional, required for R package magick for graphics
sudo apt install libpoppler-cpp-dev ## optional, required for R package pdftools to use pdf files
sudo apt install libcairo2-dev ## optional, required for R package svglite to save .svg images
sudo apt install libtesseract-dev libleptonica-dev tesseract-ocr-eng ## optional, required for R package tesseract for image-to-text processing
R --version #check for R 4.3.1 (or whichever version is the most current at this time). If you have an older version, start over from the purge line.
R #enter the R shell
Type any R code you want in the R shell.
q() #exit R shell. Can also use Ctrl+Z to exit.
Keep watch for "ERROR: configuration failed" and "non-zero exit status" errors when installing R packages. Search the internet for those errors, the R package name, and "Ubuntu" to identify which additional development packages you need to install from the Linux terminal.
sudo apt updatesudo apt upgradesudo reboot #this restarts your computer so save any files you need!
Install RStudio server (6/2024 update)
Installation instructions for Ubuntu 22.04.3 LTS on 6/21/2024 (see link below for latest filename):https://rstudio.com/products/rstudio/download-server/debian-ubuntu/
sudo apt install gdebi-corewget https://download2.rstudio.org/server/jammy/amd64/rstudio-server-2024.04.2-764-amd64.deb
sudo gdebi rstudio-server-2024.04.2-764-amd64.deb
sudo ufw allow 8787/tcp #optional, skip if you haven't enabled firewall yet
sudo systemctl status rstudio-server #check that it's working
Cntr+Z to exit the status window
If you get an an error message about a missing dependency during the RStudio server installation for Ubuntu 22.04, you might need to install an old package from Ubuntu 20.04 and retry.
echo "deb http://security.ubuntu.com/ubuntu focal-security main" | sudo tee /etc/apt/sources.list.d/focal-security.list
sudo apt update
sudo apt install libssl1.1
sudo rm /etc/apt/sources.list.d/focal-security.list
Check the RStudio server version:
rstudio-server version
First time setup for each user: ssh into the Ubuntu server from your main computer and add the server IP to your list of known hosts by answering yes to the question, "Are you sure you want to continue connecting (yes/no)?" You MUST be able to successfully ssh into the Ubuntu server before you can use the RStudio server.
From the main computer (not the server computer), either through the Windows 10 command prompt or ssh software (PuTTY or MobaXterm):ssh user@serverIP #assuming the using default port 22ssh user@serverIP -p 23 #example if ssh uses port 23
Log into the RStudio server from your main computer using a web browser, the server IP, and port 8787 [more info]:
http://<your server's IP>:8787
http://<your server name>:8787 # this also works
The login is your Ubuntu username and password.
Troubleshooting: if you can ssh into the Ubuntu server, but get a browser error saying the RStudio server website "took too long to respond", try this:
Ctrl+Z keyboard shortcut (not terminal code!) to close out systemctl
sudo systemctl start rstudio-server #only needed if status said it was inactive
sudo ufw allow 8787 #open up the port again if you have a firewall
Install Perl, Python and JupyterLab
- No need to install Perl and Python! They are already installed with Ubuntu Server 22.04.x LTS
- Check the versions with
- python3 --version #two hyphens
- python2 --version
- perl --version
- Install pip if needed for python
- sudo apt install python3-pip
- Upgrade pip
- sudo apt update
- python3 pip -m install --upgrade pip
- To exit either terminal if you're stuck, use Ctrl+Z or quit()
- ">>>" means you are in the Python shell
- Install JupyterLab (a Python GUI):
- pip3 install jupyterlab
- Detailed video instructions for installing Jupyter for a server [YouTube 2019]
- Install Spyder (a Python GUI):
- sudo apt install spyder
Install Dropbox
OLD WAY:
Manually download the latest .deb file (either 32-bit or 64-bit depending on your computer) from here: https://www.dropbox.com/install-linux
Don't follow the instructions to install from the terminal. It will partially work, but the installation code will freeze and you won't get a complete installation (my experience with Ubuntu 22.04 on 9/25/2022).
Instead, right-click the .deb file from the Downloads folder and select "Open with Software Install". You won't see this option if you right-click from the browser's download list. [More details on how to use .deb files.]
NEW WAY (6/2024):
sudo apt install nautilus-dropbox
After whichever install method you use, a pop-up window will come up. Sign in and select your preference settings.
Check the status with:
dropbox status
After rebooting, Dropbox sometimes needs to be restarted manually. You can do this remotely from a terminal using:
dropbox start
To set up Dropbox to start automatically upon login, use this command:
dropbox autostart y
See more Dropbox terminal commands from the official source or with this command:
dropbox
Make your whole hard drive space available (8/2021)
df -h #see file sizes in human readable format
cfdisk #shows all partitions on the hard drive and space used
du -sh ~/Downloads #see how much space your Downloads folder uses
du -sh ~/Dropbox #see how much space your Dropbox folder uses
df -h ~/Dropbox #see how much space is available, used, and free in this folder. Importantly, this also tells you where this folder is located on the hard drive.
sudo lsblk #shows virtual volume breakdown and which partition contains it
sudo lvresize -t -v -l +100%FREE /dev/mapper/ubuntu--vg-ubuntu--lv
df -h -T | grep vg
sudo resize2fs -p /dev/mapper/ubuntu--vg-ubuntu--lv
df -h -T |grep vg
Restart the server and you are done with this risky section.
Install a remote desktop server
Install a Brother network printer using an IP address (6/2022 update)
Network printer = a printer connected to the
internet. The printer is not connected to the computer via a USB cable
or Ethernet cable.
- Before starting, assign a static IP to your printer. This requires logging into the internet router admin page.
- Install these dependencies on your computer before installing the printer drivers:
- sudo apt install lib32zl #optional maybe
- sudo apt install lib32ncurses6 #replaces lib32ncurses5
- Look up your specific printer on the Brother website, e.g. MFC-5460CN
- Install the printer drivers [instructions, instructions from Brother]
- Download the "Driver Install Tool" file, e.g. "linux-brprinter-installer-2.2.3-1.gz", to the Downloads folder
- These instructions helped me set up a network printer with 32bit drivers on a 64bit computer
- In a terminal to install the printer drivers:
cd ~/Downloads && gunzip -v ~/Downloads/linux-brprinter*
sudo bash ~/Downloads/linux-brprinter* - Move some files to install the scanner files:
sudo ln -sf /usr/lib64/libbrscandec*.so* /usr/lib
sudo mkdir -p /usr/lib/sane
sudo ln -sf /usr/lib64/sane/libsane-brother*.so* /usr/lib/sane - Add your username to the scanner user group, e.g. gonzalez:
sudo usermod -a -G scanner gonzalez - If you get an error after a question about a proxy server, use the alternative method below.
- Install the printer drivers -- alternative method if the above doesn't work. Installing the two .deb printer drivers separately.
- From
the Brother printer page, download
the LPR printer driver and CUPSwrapper printer drivers separately (both
.deb files). Install the LPR driver first, then the CUPSwrapper.
- sudo mkdir /var/spool/lpd/
- sudo mkdir /var/spool/lpd/mfc5460cn/
- Replace the last step with whichever directory is missing. You'll see it as an error if you try to run the step below.
- sudo dpkg -i --force-all mfc5460cnlpr-1.0.1-1.i386.deb
- Replace the .deb filename with your specific LPR driver filename.
- sudo dpkg -i --force-all mfc5460cncupswrapper-1.0.1-1.i386.deb
- Replace the .deb filename with your specific CUPSwrapper driver filename.
- You should see the printer installed (under "System > Printers"). Restart the computer if not.
- The default printer settings assume you are connected by a USB cable. For a network printer, you need to change the device URI value. The default device URI value = usb:/dev/usb/lp0
- If you have a static IP for your printer, change the device URI to specify the static IP address.
- Go to "Printers" and right-click your device
- Edit printer properties and find the device URI
- Instructions: https://www.cups.org/doc/network.html
- Example static IP = 192.168.0.3
- The corresponding URI value = socket://192.168.0.3:9100
- Print a test page.
Suggested software
- Dropbox: sudo apt install nautilus-dropbox
- FTP clients - I tried all three of these for uploading RNA-seq data to NCBI GEO and I liked FileZilla the best. It had the best user interface and provided the most information about upload success.
- Google Chrome's Chromium browser: sudo apt install chromium-browser
- ImageJ - NIH funded image analysis software
- Inkscape - vector graphics software
- Jupyter Notebook
- Microsoft Edge
- OBS (Open Broadcaster Software) - video streaming and video capture software
- RStudio server (select Debian / Ubuntu as operating system)
- Vim: sudo apt install vim # a code and text editor
- WebEx
- Zoom
Expanded security maintenance
sudo pro attach [your security token]
Maintenance
- Identify your user account
- whoami #returns your account name
- Identify logged in users
- w
- Identify your Linux kernel (useful for hardware compatibility information) and Ubuntu version (useful for software compatibility):
- uname -mrs && lsb_release -a
- Identify external drive, USB flash drive, HDD, or SDD location
- RStudio server web portal starting from the Home work directory:
dir("../../[username]/media/") - Linux terminal:
ls ~/../../media/[username]/ - #replace [username] with your own username without the square brackets
- You should see your external drive name
- Download & install updates (on the server computer or remotely)
- sudo apt update #to check what is new, without installing anything
- sudo apt upgrade #to install new versions of packages
- sudo apt autoremove #to automatically remove packages that are no longer used
- Restart if the ssh log in message says: "*** System restart required ***"
- sudo reboot
- You can do this remotely by ssh
- You may need physical access to the server afterward if there are any issues with internet, firewall rules, or ssh. The most likely issue is that your need to check the IP address again if you didn't assign the server a static IP on the internet router yet.
- Check your server IP address
- ip a
- enp2s0 = ethernet
- wlp3s0 = wifi
- Check devices connected to your local internet
- sudo apt install arp-scan
- sudo arp-scan --localnet
- Check firewall rules
- sudo ufw status
- Restart Dropbox and check Dropbox status. I need to restart it often on Ubuntu server 20.04.03. It disconnects after a few hours of inactivity.
- dropbox status
- dropbox start
- RStudio Server - check status, start if inactive, restart if it is active but not working well
- systemctl status rstudio-server
- systemctl start rstudio-server
- systemctl restart rstudio-server
- RStudio Server - "took too long to respond" browser error (on the server computer or remotely)
- sudo ufw allow 8787 #reopen the 8787 port for the RStudio Server
- If that doesn't work, check your server computer's internet access.
- Check the RStudio Server link from the server computer itself (through a browser)
- http://[your server IP address]:8787
- http://192.168.0.100:8787 (example pattern)
- Check that you can ssh into the server
- Check status of the ssh service (on the server computer's terminal)
- systemctl status ssh.service #check if it's active
- systemctl restart ssh.service #restart if you're having issues
- sudo service ssh restart #try restarting another way
- sudo ufw status numbered #check which ports are open
- sudo ufw allow <your ssh port> #reopen the ssh port if needed
- Check that the server computer has internet access
- sudo lshw -class network #shows network details
- ping google.com -c2
- Wait for results from the 2 packets. If the ping statistics say 0% packet loss, then you have internet working properly.
- ping 8.8.8.8 -c2
- Wait for results from the 2 packets. If the ping statistics say 0% packet loss, then you are connected to internet even if the DNS isn't working
- If 100% packet loss, then you're not connected to internet (not a DNS problem)
- If either ping fails and says "Temporary failure in name resolution" then the DNS is not routing internet traffic correctly.
- Turn off the internet router for 30 seconds, then back on. This can fix several problems including router issues that affect every device, as well as IP assignment problems that don't affect server internet but prevent remote access through ssh or the RStudio browser url.
- Reboot the computer.
- Connect to ethernet and, if you get internet back, then download & install updates.
- If you have tried everything and nothing works, wait 1 day to see if the problem fixes itself. If not, you may need to reinstall the server.
- Check Linux kernel currently loaded. The kernel is the skeleton beneath your Ubuntu system. It is important for basic things like loading Ubuntu on startup and hardware compatibility.
- uname -a
- If you buy new hardware (e.g. wifi adapter), check that it is compatible with your Linux kernel.
- Check Linux kernels available to you. [More info]
- dpkg --list | grep linux-image
- That's two hypens before list
- It's good to have a few old versions in case an update causes startup problems. You can power down the computer, then power it on and hold the F2 key to bring up the GRUB boot loader. If you can boot using an older kernel, you might be able to resolve problems with the new kernel without reinstalling your whole system.
- Search available software by keywords, for example:
- sudo apt search "video editor"
- This will output a list of all software you have with this function
- Stress test your RAM annually with memtester, per advice from Genome Spot
- 2/8/2022 issue with "initramfs" noted after a routine apt update and apt upgrade. Rebooting stopped with this error: "[end Kernel panic - not syncing: VFS: unable to mount fs on unknown block c(0,0)]"
- Solved on Ubuntu server 20.04.03 LTS using the following commands (adapted from here). I didn't need to mount any partitions beforehand because I was not using a live CD. I accessed the GRUB boot loader (screenshot examples) and booted using an older kernel (5.4.0-97-lowlatency), then used the terminal to fix the newer kernel's initramfs:
- sudo update-initramfs -u -k 5.4.0-99-lowlatency
- Change the underlined part to suit your needs
- The
underlined part was my newest Linux kernel that failed to load. That
kernel was listed a few lines above the original "Kernel panic" error
message. If you missed that information, identify your newest kernel
using:
dpkg --list | grep linux-image - Your newest Linux kernel name may be different from mine!
- sudo update-grub
- sudo reboot
- If login screen from the GUI doesn't work, how to access the terminal
- Ctrl + Alt + F1 keys will bring up the terminal
- Turn off the computer from the terminal, then reboot:
- sudo shutdown -r now
- Turn off the computer from the terminal, without reboot:
- sudo shutdown -P now # first method
- sudo poweroff #alternative
Good luck!
- The key to success is following instructions, trial and error, checking for typos, and using the internet to find solutions for problems you'll encounter along the way
- Patience is more important than being an expert Linux user or programmer
- Break it up into a few days and stop to celebrate each completed step
- You can do this as a beginner! It seems intimidating, but it's not that bad
If you get stuck after a terminal command, use Ctrl+Z
- This is like the "Esc" key for Linux
- Ctrl+Z will exit you out of any other shells (the python shell, the R shell) or file editing (vim, nano) that you might find yourself stuck in
- Ctrl+Z stops processes and brings you back to the main terminal
Originally my notes for Ubuntu server 20.04 LTS (published December 20, 2020), but I copy/pasted and edited the notes when I installed Ubuntu server 22.04 LTS (9/25/2022). To be edited occasionally whenever I want to document down anything else I've found useful. Last edited 6/20/2024 with GUI install notes and additional port information.
No comments:
Post a Comment