top of page

What is Linux?

What is Linux?

Most people think of Linux as another operating system, just like Windows or Mac OS, that must be installed on a computer, rather than as a Kernel or a family of operating systems. This is an easy explanation, abstract enough to bring some sense and understanding to people.

What is a Kernel?

The kernel is the essential foundation of a computer's operating system (OS). It is the core that provides basic services for all other parts of the OS. It is the main layer between the OS and underlying computer hardware, and it helps with tasks such as process and memory management, file systems, device control and networking.

Summary

Linux is basically a Kernel. But in simpler terms, Linux is a technology.

 

To make it clearer, you can comparing operating systems with cars:

 

  • Windows | It is a complete car, with motorcycles, wheels, windows and steering wheel. You use this car to make all your activities, travelling, commuting to work (it is a popular car) and almost everyone that you know has a similar model. Microsoft do that car from the beginning to the end (all components), and Microsoft has an absolute control over all features and how it will looks like. Microsoft will lease that car for you through a license, and from time to time it launches some new models.

  • Mac OS | It is a very similar car, but free. The difference is you can only use the card if you live in a determined city, that Apple controls (Apple's devices). Living in this city can be very expensive, despite the car is free. You can do all your activities with this car in that city, but everytime you try to leave that city with the car, you will face some difficulties.

In both cases, you would be a customer of Microsoft and Apple, driving their cars.

  • Linux | Linux wouldn't be a complete car, but an essential component, like an engine. It can be used to create different types of cars. You don't need to pay for your Linux engine, so you are not a Linux's customer and nobody will tell you what you can do with the engine. If you transform this engine in a motorcycle, that's up to you. With the engine you receives a manual, explaining how it works and how to assemble​ it.​ The Linux engine is assemble for many companies around the world.

But now you are thinking that it's not possible to drive a engine, you need all the other components to make a car. And that where systems based on Linux are born, or distribution (distros). A very common Linux-based operating system is Ubuntu.

Linux was created by "Linus Torvalds", a Finnish developer, in 1991.

Linux Distros (Distributions Full List)

This is a list of the most relevant Linux distributions categorized by distros-based and their respective variants.​​​

Linux Distros
Distributions Based / Variants
Description
Linux Mint
Debian-based > Ubuntu-based (Unofficial Variants)
Linux Mint synchronizes its release-cycle with Ubuntu's long-term support, and is tailored to user-friendliness for desktop users.[42] Linux Mint Debian Edition (LMDE) is Mint's Debian stable based version. Its purpose is to use Debian base packages/kernel under the hood should Ubuntu ever disappear. It's also used by Mint developers to develop their Cinnamon desktop.
LinuxMCE
Debian-based > Ubuntu-based (Unofficial Variants)
Linux Media Center Edition, a Kubuntu-based distribution that provides in-depth HTPC functionality as well as home automation.[43]
LinuxTLE
Debian-based > Ubuntu-based (Unofficial Variants)
A Thai Linux distribution. Not maintained.[44]
LliureX
Debian-based > Ubuntu-based (Unofficial Variants)
A distribution by the Generalitat Valenciana[45]
LXLE Linux
Debian-based > Ubuntu-based (Unofficial Variants)
A light-weight Linux distribution based on Lubuntu, using the LXDE desktop environment.[46]
MAX
Debian-based > Ubuntu-based (Unofficial Variants)
Stands for MAdrid LinuX. Used in education.[47]
Maya OS
Debian-based > Ubuntu-based (Unofficial Variants)
A distribution developed by Indian Ministry of Defence.[48]
Molinux
Debian-based > Ubuntu-based (Unofficial Variants)
Ubuntu based initiative to introduce the Castile-La Mancha community in Spain to the information society.[49]
Netrunner
Debian-based > Ubuntu-based (Unofficial Variants)
Kubuntu based distribution with complete software and codecs installed, developed by Blue Systems (also sponsoring Kubuntu and LinuxMintKDE).[50]
Nova
Debian-based > Ubuntu-based (Unofficial Variants)
Cuban state-sponsored distribution developed at the University of Information Science, Havana. Formerly based on Gentoo.
OpenGEU
Debian-based > Ubuntu-based (Unofficial Variants)
Ubuntu based distribution with Enlightenment window manager, previously known as Geubuntu.[51]
Peppermint OS
Debian-based > Ubuntu-based (Unofficial Variants)
A light-weight LXDE distribution for cloud applications through its own Ice Framework using the Chromium Web Browser. Based on Lubuntu[52]
Pinguy OS
Debian-based > Ubuntu-based (Unofficial Variants)
An Ubuntu-based distro for people that have never used Linux before or for people that want an out-of-the-box working OS without having to tweak a fresh installation of Ubuntu or other Ubuntu-based distro.[53]
Pop! OS
Debian-based > Ubuntu-based (Unofficial Variants)
An Ubuntu-based distro developed by System76 predominantly for use on hardware that they manufacture.
Poseidon Linux
Debian-based > Ubuntu-based (Unofficial Variants)
For academic and scientific use. Based on Ubuntu, but enhanced by GIS/maps, numerical modelling, 2D/3D/4D visualization, statistics, tools for creating simple and complex graphics, programming languages.
Sabily
Debian-based > Ubuntu-based (Unofficial Variants)
Ubuntu based distribution for Muslims (formerly Ubuntu Muslim Edition)[54] Unmaintained
SuperGamer
Debian-based > Ubuntu-based (Unofficial Variants)
A Live DVD distribution focused on gaming formerly based on VectorLinux.
Trisquel GNU/Linux
Debian-based > Ubuntu-based (Unofficial Variants)
Fully free-software system without proprietary software or firmware and uses the Linux-libre kernel deblob script, based on Ubuntu LTS Releases[55]
UberStudent
Debian-based > Ubuntu-based (Unofficial Variants)
For higher education and advanced secondary students, those who teach them, and lifelong learners[56]
Ututo
Debian-based > Ubuntu-based (Unofficial Variants)
Ututo UL ("Ubuntu-Libre") Distributes Simusol, a system to simulate Solar Energy projects, returned to the heart of the project. Discontinued.[57]
Vinux
Debian-based > Ubuntu-based (Unofficial Variants)
A Linux distribution designed for visually impaired users[58]
Wubuntu
Debian-based > Ubuntu-based (Unofficial Variants)
Former LinuxFX. Also known as "Windows Ubuntu". The distribution aims to imitate Microsoft operating system Windows 10.[59][60]
Zorin OS
Debian-based > Ubuntu-based (Unofficial Variants)
Zorin OS is a user-friendly distribution that can emulate Microsoft Windows or macOS. It is meant for users unfamiliar with Linux.[61]
Knoppix
Debian-based
Knoppix (a portmanteau of the surname Knopper from Klaus Knopper and Unix) itself is based on Debian. It is a live distribution, with automated hardware configuration and a wide choice of software, which is decompressed as it loads from the drive.[62]
Damn Small Linux
Debian-based > Knoppix-based
A small Linux distro designed to run on older hardware. It is commonly used on virtual machines due to low memory requirements.[63]
Feather Linux
Debian-based > Knoppix-based
Boots from either a CD or a USB flash drive. Uses Knoppix-based hardware detection and the Fluxbox window manager.[64]
antiX
Debian-based > Other Variants
It is comparatively lightweight and suitable for older computers, while also providing kernel and applications, as well as updates and additions via the Aptitude and Debian-compatible repositories.
Astra Linux
Debian-based > Other Variants
A Russian Linux-based computer operating system developed to meet the needs of the Russian army, other armed forces and intelligence agencies.[65] It provides data protection up to the level of "top secret" in Russian classified information grade. It has been officially certified by Russian Defense Ministry, Federal Service for Technical and Export Control[66] and Federal Security Service.[67]
BOSS (Bharat OS)
Debian-based > Other Variants
An Indian Linux distribution[68]
Canaima
Debian-based > Other Variants
A Venezuelan Linux distribution.[69]
Corel Linux
Debian-based > Other Variants
Short-lived commercial desktop Linux distribution, bought by Xandros Linux.[70]
CrunchBang Linux
Debian-based > Other Variants
A small Linux Distro and Live CD based on Debian Stable, featuring the Openbox window manager and tint2 panel with GTK+ applications.[71] Development has ended for CrunchBang as of February, 2015.[72]
Deepin
Debian-based > Other Variants
A Debian-based Chinese Linux Distribution developed by Wuhan Deepin Technology Co.
Devuan
Debian-based > Other Variants
A fork of Debian begun in 2014 with the primary goal of allowing user choice in init systems, by decoupling software packages from systemd.[73]
DoudouLinux
Debian-based > Other Variants
A discontinued distribution intended for children.
Dreamlinux
Debian-based > Other Variants
A discontinued Brazilian Linux distribution.
Emdebian Grip
Debian-based > Other Variants
A small-footprint Linux distribution based on and compatible with Debian, intended for use on resource-limited embedded systems.[74]
Finnix
Debian-based > Other Variants
A small system-administration Live CD that is available for multiple architectures[75]
gLinux
Debian-based > Other Variants
gLinux is a Linux Distro used for Google Employees.
gNewSense
Debian-based > Other Variants
Originally based on Ubuntu and later upon Debian, and developed with sponsorship from the Free Software Foundation. Its goal is user-friendliness, but with all proprietary (e.g. binary blobs) and non-free software removed.

Debian Operating System 

Debian had a long history. Founded in 1993 by Ian Murdock, it is one of the early Linux distributions and one that is the basis for many other Linux distributions. 

 

Debian releases are named for characters from the Toy Story movies. 

 

  • Debian 1.1 Buzz (June 17th, 1996): Named for the Buzz Lightyear.

  • Debian 1.2 Rex (December 12th, 1996): Named for the plastic dinosaur in the Toy Story movies.

  • Debian 1.3 Bo (June 5th, 1997): Named for Bo Peep, the shepherdess. 

  • Debian 2.0 Hamm (July 24th, 1998): Named for the piggy-bank in the Toy Story movies. 

  • Debian 2.1 Slink (March 9th, 1999): Named for the slinky-dog in the movie. 

  • Debian 2.2 Potato (15 August 2000): Named for "Mr Potato Head" in the Toy Story movies. 

  • Debian 3.0 Woody (19 July 2002): Named for the main character the Toy Story movies: "Woody" the cowboy. 

  • Debian 3.1 Sarge (6 June 2005): Named for the sergeant of the Green Plastic Army Men.

  • Debian 4.0 Etch (8 April 2007): Named for the sketch toy in the movie. 

  • Debian 5.0 Lenny (February 2009): Named for the wind up binoculars in the Toy Story movies. 

  • Debian 6.0 Squeeze (February 2011): Named for the green three-eyed aliens.

  • Debian 7.0 Wheezy (May 2013): Named for the rubber toy penguin with a red bow tie.

  • Debian 8 Jessie (April 2015): Named for the cow girl doll who first appeared in Toy Story 2.

  • Debian 9 Stretch (June 2017): Named for the toy rubber octopus with suckers on her eight long arms that appeared in Toy Story 3.

  • Debian 10 Buster (July 2019): Named for Andy's pet dog, received as Christmas present in the end of Toy Story.

  • Debian 11 Bullseye (August 14th, 2021): Named for Woody's wooden toyhorse that appeared in Toy Story 2.

User Interface (UI) | CLI vs GUI

Usually there are two different interfaces available in all operating systems. These interfaces are Command Line Interface (CLI) and Graphical User Interface (GUI).

What are the different types of UIs (User Interfaces)?

  • CLI (Command-Line Interface) | A command-line interface is a means of interacting with a computer program by inputting lines of text called command-lines. Command-line interfaces emerged in the mid-1960s, on computer terminals, as an interactive and more user-friendly alternative to the non-interactive interface available with punched cards.

  • GUI (Graphical User Interface) | A graphical user interface is a form of user interface that allows users to interact with electronic devices through graphical icons and visual indicators such as secondary notation. In many applications, GUIs are used instead of text-based UIs, which are based on typed command labels or text navigation.

Linux GUI | Graphical User Interface

Linux provides variety of GUI known as desktop environment. Each desktop environment has peculiar features. The most popular and widely used desktop environments available on Linux are:

 

  • GNOME | GNOME is bundled as the default desktop environment for many distributions, including RHEL, Fedora, CentOS, SUSE Linux Enterprise, and Debian. GNOME has menu-based navigation

  • KDE | KDE is another popular desktop environment, KDE is often used in SUSE and openSUSE

  • XFCE | XFCE is a free and open-source desktop environment for Linux and other Unix-like operating systems. Xfce aims to be fast and lightweight while still being visually appealing and easy to use. It embodies the traditional Unix philosophy of modularity and re-usability

  • LXDE | LXDE (Lightweight X11 Desktop Environment) is a free, open-source desktop environment for Linux that is designed to be fast, energy-efficient, and lightweight. It's a good choice for older or resource-constrained computers, such as netbooks, mobile devices, or cloud computers

  • Unity | In Unity, the graphical user interface (GUI) is a subset of the user interface (UI) that includes graphical representations like images, animations, and icons

SSH (Secure Shell) | Remote Access

Secure Shell (SSH) is a network protocol that allows users to securely connect to and access computers, routers, and servers over an unsecured network. SSH is often used for remote logins, file transfers, and managing applications. 

Key Features

  • Encryption: SSH encrypts communication between computers, making it suitable for use on insecure networks

  • Remote access: SSH allows users to remotely log in to and perform operations on other computers

  • File transfer: SSH enables users to securely transfer files between computers

  • Tunneling: SSH also enables tunneling

  • Automated access: SSH tools can be used by non-human entities to access other devices with little to no human intervention

 
SSH Design: The first version of SSH designed in 1995 by Tatu Ylönen, a researcher at Helsinki University of Technology in Finland.

How to access Linux terminal remotely through Windows

It is possible to access the Linux terminal remotely using Windows PowerShell through SSH (Secure Shell).

Installing SSH on Linux

  • For non-root users, use the command "sudo" to perform administrative tasks​

  • Update the list of available packages and their versions stored | Command: apt update

  • Install SSH | Command: apt install openssh-server

Accessing SSH

  • On Windows, open "Powershell"

  • Establish connection | Command: SSH <username>@<linux ip>

    • Example: SSH johnsmith@10.10.1.217

  • When connection question pops up, choose "Yes"

  • Insert your "Password"

  • The Linux Terminal will be connected

Accessing SSH using "Root" User

  • On Linux machine, open the Terminal

  • For non-root users, use the command "sudo" to perform administrative tasks​

  • (Optional) If you've never used "root" user before, change password | Command: sudo passwd root

  • Inform your password to elevate your "sudo" rights, than inform the "root" password, and confirm it

  • Edit the SSH config to "Permit Root Login" | Command: nano /etc/ssh/sshd_config

  • Find the line "#PermitRootLogin prohibit-password" and change to "PermitRootLogin yes"

  • Press "Ctrl+X", yes to save it

  • Restart the SSH service

    • 1 Option | Restart only the SSH service | Command: systemctl restart ssh

    • 2 Option | Restart the Linux machine | Command: shutdown -r now

  • Try to access again with "root" user (see all steps above) | Command: ssh root@<linux ip>

Installing Packages

How to install packages on Ubuntu with one command line.

Preparing to install the packages

 

  1. For non-root users, use the command "sudo" to perform administrative tasks​

  2. It is recommended run the update command (if your system is not updated) | Command: apt update

  3. Than, check if you already have the package | Command: <package> --version

Installing the desired packages

  • Netstat | Command: apt install net-tools

    • Netstat derived from the words network and statistics and it is a command-line utility used by system administrators for analyzing network statistics. It displays a whole manner of statistics such as open ports and corresponding addresses on the host system, routing table, and masquerade connections

  • NMap | Command: apt install nmap

    • ​Nmap is a powerful network discovery and security auditing utility that is free, open-source, and easy to install. Nmap scans for vulnerabilities on your network, performs inventory checks, and monitors host or service uptime, alongside many other useful features.

  • Snap | Command: apt install snapd

    • Snap is a software packaging and deployment system developed by Canonical for operating systems that use the Linux kernel and the systemd init system

  • Curl | Command: apt install curl

    • Curl (Client URL) is a command-line tool used for transferring data with various protocols, including HTTP, HTTPS, FTP, and many more. Ubuntu, being one of the most popular Linux distributions, often has curl available in its software repositories. This allows users to easily install and update curl using Ubuntu’s package management tools like apt

  • Crontab | Command: apt install cron

    • The cron command-line utility is a job scheduler on Unix-like operating systems. Users who set up and maintain software environments use cron to schedule jobs, also known as cron jobs, to run periodically at fixed times, dates, or intervals.​

Hostname

How to check and manage hostname

  • For non-root users, use the command "sudo" to perform administrative tasks​

  • Check your current Hostname | Command: hostname

  • Check additional Hostname information | Command: hostnamectl

  • Change the Hostname | Command: hostnamectl set-hostname <New-Hostname>

    • Example: hostnamectl set-hostname ubuntu

Linux | Timezone

How to check and manage timezone

  • For non-root users, use the command "sudo" to perform administrative tasks​

  • Check your current Timezone | Command: timedatectl

  • Verify the list of all timezones | Command: timedatectl list-timezones

  • Or you can find the right timezone per city | Command: timedatectl list-timezones | grep <city>

    • Example: timedatectl list-timezones | grep London

  • Change the Timezone | Command: timedatectl set-timezone <timezone>

    • Example: timedatectl set-timezone Europe/London

  • Check your new Timezone | Command: timedatectl

Linux | Mounting an SMB Drive

How to Mount an SMB Drive on Ubuntu

Mount an SMB Password-Protected Share Drive

  • Open your Linux Terminal

  • For non-root users, use the command 'sudo' to perform administrative tasks​

  • Install CIFS | Command: apt install cifs-utils

  • Create the Mount Directory | Command: mkdir <local-directory>

    • Example: mkdir /mnt/smb-media

  • (Optional) Check details about file systems | Command: stat <local-directory>

    • Example: stat /mnt/smb-media

    • File System Info | Access: (0777/drwxrwxrwx)  UID: (0/root) GID: (0/root)

    • Changing Directory Permission | If you need change the directory permission | Check it here

  • Mount the SMB Drive | Command: mount -t cifs -o username=<user>,password=<password>,uid=0,gid=0,rw,nounix,iocharset=utf8,file_mode=0777,dir_mode=0777 //<smb-ip-address>/<sharedrive-name> <local-directory>

    • Example: mount -t cifs -o username=JohnSmith,password=Secret123,uid=0,gid=0,rw,nounix,iocharset=utf8,file_mode=0777,dir_mode=0777 //192.168.0.115/storage /mnt/smb-media

    • (Optional) If you want to mount a specific directory inside the SMB drive | //<smb-ip-address>/<sharedrive-name>/<directory> | Example: //192.168.115/storage/media

  • Verify that SMB is mounted correctly | Command: ls <local-directory>

    • Example: ls /mnt/smb-media

Auto-mount on boot an SMB Password-Protected Share Drive Permanently

  • Open your Linux Terminal

  • For non-root users, use the command 'sudo' to perform administrative tasks​

  • Install CIFS | Command: apt install cifs-utils

  • Create the Mount Directory | Command: mkdir <local-directory>

    • Example: mkdir /mnt/smb-media

  • Edit the 'fstab' file | Command: nano /etc/fstab

  • Add this line | //<smb-ip-address>/<sharedrive-name> <local-directory> cifs username=<user>,password=<password> 0 0

    • Example: //192.168.0.115/storage /mnt/smb-media cifs username=JohnSmith,password=Secret123 0 0

    • (Optional) If you want to mount a specific directory inside the SMB drive | //<smb-ip-address>/<sharedrive-name>/<directory> | Example: //192.168.115/storage/media

  • Reload the new 'fstab' version | Command: systemctl daemon-reload

  • Mount the SMB Drive | Command: mount <local-directory>

    • Example: mount /mnt/smb-media

  • Verify that SMB is mounted correctly | Command: ls <local-directory>

    • Example: ls /mnt/smb-media

Unmount the SMB Drive

  • 1 Option | Unmount the drive

    • (Optional) If you are inside the drive, leave the directory or it will be currently busy | Command: cd

    • Unmount the Drive| Command: umount -i <local-drive>

      • Example: umount -i /mnt/smb-media

  • 2 Option | Unmount the permanent drive

    • Edit the 'fstab' file| Command: nano /etc/fstab

    • Remove the previous added line | //<smb-ip-address>/<sharedrive-name> <local-directory> cifs username=<user>,password=<password> 0 0

    • Reload the new 'fstab' version | Command: systemctl daemon-reload

    • (Optional) If you are inside the drive, leave the directory or it will be currently busy | Command: cd

    • Unmount the Drive| Command: umount -i <local-drive>

      • Example: umount -i /mnt/smb-media

  • 3 Option | Unmount the drive if the target is busy or currently in use (be careful) | Laze Unmount

    • (Optional) Verify the processes | Command: lsof | grep <local-drive>

      • Example: lsof | grep /mnt/smb-media

    • Leave the directory | Command: cd

    • Unmount the Drive (laze unmount)| Command: umount -l <local-drive>

      • Example: umount -l /mnt/smb-media

Linux | Change Mode (chmod) | Access Permission

 

Purpose

The chmod, or change mode, command allows an administrator to set or modify a file’s permissions. Every UNIX/Linux file has an owner user and an owner group attached to it, and every file has permissions associated with it.

 

The permissions are as follows: Read, Write, or Execute.

Application

UNIX/Linux systems have many users. In this context, a user may refer to an individual or a system operation. UNIX/Linux identifies each user with a UID, and users may be organized into groups.

Syntax

  • Chmod Syntax for Files| Command: chmod <mode/access-code> <file>

    • Example: chmod 720 readme.txt

  • Chmod Syntax for Directories| Command: chmod <mode/access-code> <directory>

    • Example: chmod 777 /mnt/sharedfolder

Each number in the mode parameter represents the permissions for a user or group of users:

  • The first number represents the file’s owner

  • The second number represents the file’s group

  • The third number represents everyone else

 

The Change Mode (chmod) Parameters Reference Table below shows the eight numbers that can be used within the chmod parameter.

 

The RWX specifies Read, Write, and Execute access, offering a binary value for each operation.

  • 1 = "Yes"

  • 0 = "No"

 

If RWX reads 110, then that permission may Read and Write, but not Execute.

Parameters Reference

Number 0 | None | RWX 000

Number 1 | Execute Only | RWX 001

Number 2 | Write Only | RWX 010

Number 3 | Write and Execute | RWX 011

Number 4 | Read Only | RWX 100

Number 5 | Read and Execute | RWX 101

Number 6 | Read and Write | RWX 110

Number 7 | Read, Write, and Execute | RWX 111

Example 1

  • Access Code = 720

    • 7 = File’s owner may Read, Write and Execute the file

    • 2 = File’s group may only Write the file

    • 0 = All others cannot access the file

Example 2

  • Access Code = 600

    • 6 = File’s owner may Read and Write the file

    • 0 = File’s group cannot access the file

    • 0 = All others cannot access the file​​​

Linux | File Hierarchy Structure

Linux file hierarchy structure describes the directory structure and it's contents in Unix and Unix-like Operating systems. It is maintained by Linux Foundation.

  • /bin

    • /bin | This directory contains executable programs which are needed in single user mode and to bring the system up or repair it

    • /usr/X11R6/bin | Binaries which belong to the X-Window system; often, there is a symbolic link from the more traditional /usr/bin/X11 to here.

    • /usr/bin | This is the primary directory for executable programs.  Most programs executed by  normal  users  which are  not  needed  for booting or for repairing the system and which are not installed locally should be

    • /usr/local/bin | Binaries for programs local to the site. It contains binaries of the third-party apps we install. Any local executable that didn't come with the Linux install may get it's place here 

  • /boot

  • /dev

  • /etc

  • /lib

  • /media

  • /mnt

  • /opt

  • /home

  • /var

  • /usr

  • /tmp

  • /sys

  • /proc

  • /root

  • /sbin | It contains the binaries for root users

/etc/ssl/certs/

/etc/ssh/sshd_config

/etc/passwd

Linux | SAMBA (SMB)

Samba is an open-source software package that allows users to share files and print services across a network, including between Linux and Windows systems. It's a common way to network Ubuntu and Windows computers. 

Samba uses the Server Message Block (SMB) and Common Internet File System (CIFS) protocols, making it available to clients running Linux, macOS, and Windows. It's a useful service for organizations that support multiple operating systems, and can also be useful on networks that are homogeneous. 


Here are some things Samba can do:

  • File sharing: Samba allows users to share files, directories, and print services across a network

  • Access permissions: Samba allows users to grant read, write, and anonymous access permissions on a shared directory

  • Authentication and authorization: Samba supports authentication and authorization

  • Name resolution: Samba supports name resolution, such as DNS

  • Service announcements: Samba supports service announcements between Linux/Unix servers and Windows clients

Install and Configure Samba on Ubuntu

  • Open your Linux Terminal

  • For non-root users, use the command "sudo" to perform administrative tasks​

  • Install Samba | Command: apt install samba

  • (Optional) Check the installation | Command: whereis samba

    • Output Example: samba: /usr/sbin/samba /usr/lib/samba /etc/samba /usr/share/samba /usr/share/man/man7/samba.7.gz /usr/share/man/man8/samba.8.gz

  • (Optional) Create a directory to share | Command: mkdir /home/public

  • ​Configuring Samba File, open the CONF file | Command: nano /etc/samba/smb.conf

    • Copy and paste the lines below in the bottom of the file and save it:

      • Lines:

[share]
    comment = Ubuntu File Server Share
    path = /home/public
    browsable = yes
    guest ok = yes
    read only = no
    create mask = 0755

  • Restart the service | Command: service smbd restart

  • (Optional) Maybe you need to adjust your firewall | Command: ufw allow samba

* Warning: Your directory maybe not showing in the Windows Network, but it is there, and you can map it as network drive

Linux | Certificates

How to add a Certificate on Ubuntu

  • Issue your Certificate

  • Open your Linux Terminal

  • For non-root users, use the command "sudo" to perform administrative tasks​

  • (Optional) If your system id not updated | Update Ubuntu | Command: apt update

  • (Optional) If you don't have the CA-Certificate | Command: apt install ca-certificates -y

  • 1 Option | If you already have your Certificate file in the system

    • Go to certificate directory | Command: cd <directory-of-certificate>

    • Copy the certificate to right directory | Command: cp local-ca.crt /usr/local/share/ca-certificates

  • 2 Option | Create the certificate ".crt" file direct in the directory

    • Go to Certificate directory | Command: cd /usr/local/share/ca-certificates

    • Create the file ".crt" | Command: nano <FileName>.crt

      • Example: nano myCert.crt

    • Copy and Past you Certificate key to the file, exit "Ctrl+X" and Save it

  •  Update the Certificates | Command: update-ca-certificates

  • The CA trust store (as generated by update-ca-certificates) will be available, as a single file (PEM bundle), at /etc/ssl/certs/ca-certificates.crt

  • You can check the file | Command: nano /etc/ssl/certs/ca-certificates.crt

Linux | Unattended Upgrades

Check the Debian Unattended Upgrades page: https://wiki.debian.org/UnattendedUpgrades

Install Unattended Upgrades on Ubuntu

  • Open your Linux Terminal

  • For non-root users, use the command "sudo" to perform administrative tasks​

  • Install Unattended-Upgrades package | Command: apt-get install unattended-upgrades apt-listchanges

 

Configuring Unattended Upgrades

  • Copy file | Command: cp /etc/apt/apt.conf.d/50unattended-upgrades /etc/apt/apt.conf.d/52unattended-upgrades-local

  • Configure the unattended upgrades | Command: nano /etc/apt/apt.conf.d/52unattended-upgrades-local

    • This '50' file will be overwritten by '52': /etc/apt/apt.conf.d/50unattended-upgrades
  • Configure '20auto-upgrades' | Command: dpkg-reconfigure unattended-upgrades

    • Confirm with 'yes'

    • This file is modified (you can also configure directly) | File: /etc/apt/apt.conf.d/20auto-upgrades

  • Configure 'apt-listchanges' | Command: nano /etc/apt/listchanges.conf

 

Changing Schedules

  • Update Schedule | Command: systemctl edit apt-daily.timer

    • Restart Schedule | Command: systemctl restart apt-daily.timer

    • (Optional) Checking Status | Command: systemctl status apt-daily.timer

    • Original schedule file | File: /lib/systemd/system/apt-daily.timer

      • Recommended to not change the original, but if you do, reload it | Command: systemctl daemon-reload

    • Gets overridden by | File: /etc/systemd/system/apt-daily.timer.d/override.conf

  • Upgrade Schedule | Command: systemctl edit apt-daily-upgrade.timer

    • Restart Schedule | Command: systemctl restart apt-daily-upgrade.timer

    • (Optional) Checking Status | Command: systemctl status apt-daily-upgrade.timer

    • Original schedule file | File: /lib/systemd/system/apt-daily-upgrade.timer

      • Recommended to not change the original, but if you do, reload it | Command: systemctl daemon-reload

    • Gets overridden by| File: /etc/systemd/system/apt-daily-upgrade.timer.d/override.conf

 

Verifying Unattended Upgrades

  • (Optional) Manual Run | Command: unattended-upgrade -d

  • (Optional) Check Unattended Upgrades Log | Command: nano /var/log/unattended-upgrades/unattended-upgrades.log

Warnings

  • Email: To receive emails, you need to set up email first (using postfix for example) and then set up unattended updates

  • Schedule: You only check the agenda correctly the next day, after the calendar is reset correctly

Config Files

Example of how to override the download time via 'apt-daily.timer'

[Unit]

Description=Daily apt download activities

 

[Timer]

OnCalendar=

OnCalendar=*-*-* 6,18:00

RandomizedDelaySec=12h

Persistent=true

 

[Install]

WantedBy=timers.target

Example of how to override the download time via 'apt-daily-upgrade.timer'

[Unit]

Description=Daily apt upgrade and clean activities
After=apt-daily.timer

 

[Timer]

OnCalendar=

OnCalendar=*-*-* 06:00

RandomizedDelaySec=2h

Persistent=true

 

[Install]

WantedBy=timers.target

Example of 'listchanges.conf'

[apt]
frontend=pager
which=both
email_address=root
email_format=text
confirm=false
headers=false
reverse=false
save_seen=/var/lib/apt/listchanges.db

Bash Scripting

How to Create and Execute Bash scripts

Script naming conventions

By naming convention, bash scripts end with ".sh". However, bash scripts can run perfectly fine without the "sh" extension.

Adding the Shebang

Bash scripts start with a "shebang". Shebang is a combination of "bash #" and "bang !" followed by the bash shell path. This is the first line of the script. Shebang tells the shell to execute it via bash shell. Shebang is simply an absolute path to the bash interpreter. 

 

Bash Shell Path | Command: which bash

Examples of the shebang statement:

  • #! /bin/bash

  • #! /user/bin/bash

Creating your Bash Script

  • For non-root users, use the command "sudo" to perform administrative tasks​

  • Creating a directory to your script | Command: mkdir <directory>

    • Example: mkdir /home/script

  • Creating the file name with "touch" | Command: touch <filename>

    • Example: touch /home/script/update.sh

  • Assign execution rights to your user, to make the script executable | Command: chmod u+x <filename>

    • Example: chmod u+x /home/script/update.sh

    • "chmod" modifies the ownership of a file for the current user "u"

    • "+x" adds the execution rights to the current user. This means that the user who is the owner can now run the script

    • "update.sh" is the file we wish to run

  • Open with editor "nano" to create your script | Command: nano <filename>

    • Example: nano /home/script/update.sh

  • Write your Script | Check the example below to update your Ubuntu

  • When you finish it, press Ctrl+X and Save

  • To run your script | Command: bash <filename>

    • Example: bash /home/script/update.sh

    • Other example: sh /home/script/update.sh

Example to run the update

---

#! /bin/bash

# Update and Upgrade

apt-get update; apt-get dist-upgrade -y

# Remove and Clean

apt-get autoremove; apt-get autoclean

#Write a Log

echo "Update Run: `date`" >> /home/script/update.log

# End

exit

---

Executing Bash Scripts on Multiple Remote Servers

How to access a remote server bypassing the password prompt

You can use a RSA Keypair to bypass the password request.

  • Open your Linux Terminal on Local Server

  • For non-root users, use the command "sudo" to perform administrative tasks​

  • Generating a RSA Keypair | Command: ssh-keygen

    • Enter file in which to save the key: Blank

    • Passphrase: Blank

    • Confirm Passphrase: Blank

  • Two files will be created

    • Example: "id_rsa" ans "id_rsa.pub"

    • You can see the files in the ssh directory | Command: cd ~/.ssh

  • Copy the keypair to the Remote Server | Command: ssh-copy-id <userid>@<hostname>

    • Example: ssh-copy-id root@ubuntu.home.arpa

    • You can see the rsa keypair copied | Command: cat ~/.ssh/authorized_keys

  • Now you can log in without a password | Command: ssh <userid>@<hostname>

How to run a local script on a remote server

You can use the options below to run a local script on a remote server without having the script on your remote server.

Option 1 | Command: ssh user@remote_server 'bash -s' < localfile
Option 2 | Command: ssh user@remote_server "$(< localfile)"

Option 3 | Command: cat localfile | ssh user@remote_server

How to run a local script on multiple remote servers

You can create a script to run a script on multiple remote servers.

Username = This is the username of your remote server

Hosts = This is your remote servers

Script = This is your command to run your script (see options above)

Example:

---

#! /bin/bash
USERNAME="root"
HOSTS="ubuntu1.home.arpa ubunt2.home.arpa"
SCRIPT="bash -s < /home/update.sh"
for HOSTNAME in ${HOSTS}
do
  ssh -l ${USERNAME} ${HOSTNAME} "${SCRIPT}"
done

---

Linux | Commands

  • ssh - Secure Shell command in Linux

  • sudo - Command to escalate privileges in Linux

  • ls - The most frequently used command in Linux to list directories

  • pwd - Print working directory command in Linux

  • cd - Linux command to navigate through directories

  • mkdir - Command used to create directories in Linux

  • mv - Move or rename files in Linux

  • cp - Similar usage as mv but for copying files in Linux

  • rm - Delete files or directories

  • touch - Create blank/empty files

  • ln - Create symbolic links (shortcuts) to other files

  • cat - Display file contents on the terminal

  • clear - Clear the terminal display

  • echo - Print any text that follows the command

  • less - Linux command to display paged outputs in the terminal

  • man - Access manual pages for all Linux commands

  • uname - Linux command to get basic information about the OS

  • whoami - Get the active username

  • tar - Command to extract and compress files in Linux

  • grep - Search for a string within an output

  • head - Return the specified number of lines from the top

  • tail - Return the specified number of lines from the bottom

  • diff - Find the difference between two files

  • cmp - Allows you to check if two files are identical

  • comm - Combines the functionality of diff and cmp

  • sort - Linux command to sort the content of a file while outputting

  • export - Export environment variables in Linux

  • zip - Zip files in Linux

  • unzip - Unzip files in Linux

  • service - Linux command to start and stop services

  • ps - Display active processes

  • kill and killall - Kill active processes by process ID or name

  • df - Display disk filesystem information

  • mount - Mount file systems in Linux

  • chmod - Command to change file permissions

  • chown - Command for granting ownership of files or folders

  • ifconfig - Display network interfaces and IP addresses

  • traceroute - Trace all the network hops to reach the destination

  • wget - Direct download files from the internet

  • ufw - Firewall command

  • iptables - Base firewall for all other firewall utilities to interface with

  • apt, pacman, yum, rpm - Package managers depending on the distro

  • cal - View a command-line calendar

  • alias - Create custom shortcuts for your regularly used commands

  • dd - Majorly used for creating bootable USB sticks

  • whereis - Locate the binary, source, and manual pages for a command

  • whatis - Find what a command is used for

  • top - View active processes live with their system usage

  • useradd and usermod - Add new user or change existing users data

  • passwd - Create or update passwords for existing users

Command
Description
Type
Example
Comments
head -n <line-count> <filename>
Show first few lines in file
File Content
tail -f <filename>
Follow file changes
File Content
tail -n <line-count> <filename>
Show last few lines in file
File Content
cd
Change current directory
File Management
cp -Rf <src-dirname> <dst-dirname>
Copy directory
File Management
cp <src-filename> <dst-filename>
Copy file
File Management
find . -iname <filename-regex>
Find files
File Management
find . -type f
Find all files
File Management
ls
List files in the current directory
File Management
ls -alh
List files in the current directory with details
File Management
mkdir
Create an empty directory
File Management
mv <src-filename> <dst-filename>
Move file or directory
File Management

References: Wikipedia (www.wikipedia.org); Google (www.google.com); Oracle (www.oracle.com); Raspberry PI (www.raspberrypi.org); Microsoft (www.microsoft.com); CloudFlare (www.cloudflare.com)

background.avif
© 2026 SAP NFe. All Rights Reserved.
bottom of page