Saturday, December 31, 2016

dataset

http://mmlab.ie.cuhk.edu.hk/projects/CelebA.html

CelebFaces Attributes Dataset (CelebA) is a large-scale face attributes dataset with more than 200K celebrity images, each with 40 attribute annotations.

http://www.comp.leeds.ac.uk/mat4saj/lsp.html
This dataset contains 2000 pose annotated images of mostly sports people gathered from Flickr

http://cs.nyu.edu/~silberman/datasets/nyu_depth_v2.html

Indoor Segmentation and Support Inference from RGBD Images


http://mscoco.org/
COCO is a new image recognition, segmentation, and captioning dataset. COCO has several features:

uninstall XQuartz on Mac

launchctl unload /Library/LaunchAgents/org.macosforge.xquartz.startx.plist
sudo launchctl unload /Library/LaunchDaemons/org.macosforge.xquartz.privileged_startx.plist
sudo rm -rf /opt/X11* /Library/Launch*/org.macosforge.xquartz.* /Applications/Utilities/XQuartz.app /etc/*paths.d/*XQuartz
sudo pkgutil --forget org.macosforge.xquartz.pkg


# Log out and log in

Mask r-cnn Faster r-cnn

https://blog.athelas.com/a-brief-history-of-cnns-in-image-segmentation-from-r-cnn-to-mask-r-cnn-34ea83205de4

Mask R-CNN
https://arxiv.org/abs/1703.06870
http://kaiminghe.com
https://www.zhihu.com/question/57403701

Faster R-CNN
https://github.com/rbgirshick/py-faster-rcnn

https://devtalk.nvidia.com/default/topic/974063/caffe-failed-with-py-faster-rcnn-demo-py-on-tx1/




Monday, December 19, 2016

Caffe Tutorial

https://vision.princeton.edu/courses/COS598/2015sp/slides/Caffe/caffe_tutorial.pdf

https://docs.google.com/presentation/d/1UeKXVgRvvxg9OUdh_UiC5G71UMscNPlvArsWER41PsU/edit#slide=id.gc2fcdcce7_216_339

http://caffe.berkeleyvision.org/

http://caffe.berkeleyvision.org/gathered/examples/mnist.html




Friday, December 16, 2016

Ubuntu 16.04 + GTX1080 + Caffe

USB install Ubuntu 16.04

sudo apt-get install ssh
sudo service ssh restart

sudo add-apt-repository ppa:graphics-drivers/ppa
sudo apt-get update
sudo apt-get install nvidia-367 (no need to upgrade to 370 as CUDA 8 use 367)

download 

linux-headers-4.7.0-040700_4.7.0-040700.201608021801_all.deb

linux-headers-4.7.0-040700-generic_4.7.0-040700.201608021801_amd64.deb

linux-image-4.7.0-040700-generic_4.7.0-040700.201608021801_amd64.deb




sudo dpkg -i *.deb



upgrade to kernel 4.7

fix Intel Dual BandWireless-AC 3168



sudo dpkg -i linux-firmware_1.161_all.deb


CUDA

wget http://developer.download.nvidia.com/compute/cuda/repos/ubuntu1604/x86_64/cuda-repo-ubuntu1604_8.0.44-1_amd64.deb
sudo dpkg -i cuda-repo-ubuntu1604_8.0.44-1_amd64.deb
sudo apt-get update
sudo apt-get install cuda


https://yangcha.github.io/GTX-1080/ 
cuDNN 5.1
tar xvzf cudnn-8.0-linux-x64-v5.1.tgz
sudo cp cuda/include/cudnn.h /usr/local/cuda/include
sudo cp cuda/lib64/libcudnn* /usr/local/cuda/lib64
sudo chmod a+r /usr/local/cuda/include/cudnn.h /usr/local/cuda/lib64/libcudnn*
 


Install Caffe
https://github.com/BVLC/caffe/wiki/Ubuntu-16.04-or-15.10-Installation-Guide 

sudo apt-get update

sudo apt-get -y upgrade

sudo apt-get install -y build-essential cmake git pkg-config

sudo apt-get install -y libprotobuf-dev libleveldb-dev libsnappy-dev libhdf5-serial-dev protobuf-compiler

sudo apt-get install -y libatlas-base-dev 

sudo apt-get install -y --no-install-recommends libboost-all-dev

sudo apt-get install -y libgflags-dev libgoogle-glog-dev liblmdb-dev

# (Python general)
sudo apt-get install -y python-pip

# (Python 2.7 development files)
sudo apt-get install -y python-dev
sudo apt-get install -y python-numpy python-scipy

# (or, Python 3.5 development files)
sudo apt-get install -y python3-dev
sudo apt-get install -y python3-numpy python3-scipy

# (OpenCV 2.4)
sudo apt-get install -y libopencv-dev
 
git clone https://github.com/BVLC/caffe.git

cd caffe
 
cp Makefile.config.example Makefile.config

vi Makefile.config
 
cd python

for req in $(cat requirements.txt); do pip install $req; done
 
cd ..

vi Makefile

make all
make test
make runtest
make pycaffe  
make distribute
 
The binary models can be download with the following script. In caffe-master directory, 

cd scripts
./download_model_binary.py ../models/bvlc_alexnet/
./download_model_binary.py ../models/bvlc_googlenet/
./download_model_binary.py ../models/bvlc_reference_caffenet/
./download_model_binary.py ../models/bvlc_reference_rcnn_ilsvrc13/
./download_model_binary.py ../models/finetune_flickr_style/
 
 
 
Python
sudo apt-get install python-tk 



 
 

Saturday, December 10, 2016

Ansible : lineinfile

https://groups.google.com/forum/#!msg/ansible-project/JvHfchsgRaU/Vw_CzBbvadgJ

-- code extract ----
  # Regexp implementation note:

  #  - the line to match follows the following pattern:

  #     - <startofline>: matched by ^

  #     - A number of white spaces/tabs: matched by \s+

  #     - the "kernel" string: matched by kernel

  #     - A list of: <spaces|tab><string> -> this is all the options passed to the kernel

  #     - possible spaces and tabs at the end : matched by the latest \s*

  #     - the <end of line>: matched by $

  #  - the list of: <spaces|tab><string1> described above 

  #    e.g:  /vmlinuz-2.6.32-358.el6.x86_64 ro root=/dev/mapper/VolGroup00-root_vol … rd_LVM_LV=VolGroup00/root_vol SYSFONT=latarcyrheb-sun16 rd_NO_DM

  #    is matched by: (\s+(?!pcie_aspm=off)[\w=/\-\.]+)*

  #    The (?!pcie_aspm=off) is to direct the regexp engine to check that the string 'pcie_aspm=off' 
is not present

  #       anywhere in the in the <string1> part. This is called negative lookahead.

  #       This is just a check, no characters are "consumed". The following [\w=/\-\.]+

  #       is ther to consume aka match any strings made of alphanumeric characters,the '/', the '-', the '.'  

  #  - if the 'pcie_aspm=off' string is present, there is no match

  #  - the capturing group 1 referred as to \1 in the line= statement 

  #    will capture the whole line but the trailing <withe spaces> and <end of line>

  

    

  - name: Activate a lacking kernel option 'pcie_aspm=off' in {{ targetgrub }}

    lineinfile: dest={{ targetgrub }}

              backup=True

              backrefs=True

              state=present

              regexp='(^\s+kernel(\s+(?!pcie_aspm=off)[\w=/\-\.]+)*)\s*$'

              line='\1 pcie_aspm=off'



-- end of code extract ----

http://daveops.co.uk/2014/05/using-ansible-to-append-a-string-to-the-end-of-a-line/

http://www.handverdrahtet.org/2016/01/ansible-using-numbered-backreference.html

Friday, December 9, 2016

Ubuntu 16.10 + GTX 1080

USB install Ubuntu 16.10

$ uname -r
4.8.0-30-generic

Ctrl+Alt+T to start terminal as mouse not working

sudo apt-get install ssh
sudo service ssh restart

Fix mouse not working problem

sudo add-apt-repository ppa:graphics-drivers/ppa
sudo apt-get update
sudo apt-get install nvidia-367

https://yangcha.github.io/GTX-1080/


wget http://developer.download.nvidia.com/compute/cuda/repos/ubuntu1604/x86_64/cuda-repo-ubuntu1604_8.0.44-1_amd64.deb
sudo dpkg -i cuda-repo-ubuntu1604_8.0.44-1_amd64.deb
sudo apt-get update
sudo apt-get install cuda
$ nvidia-smi
Fri Dec  9 23:21:17 2016       
+-----------------------------------------------------------------------------+
| NVIDIA-SMI 367.57                 Driver Version: 367.57                    |
|-------------------------------+----------------------+----------------------+
| GPU  Name        Persistence-M| Bus-Id        Disp.A | Volatile Uncorr. ECC |
| Fan  Temp  Perf  Pwr:Usage/Cap|         Memory-Usage | GPU-Util  Compute M. |
|===============================+======================+======================|
|   0  GeForce GTX 1080    Off  | 0000:01:00.0      On |                  N/A |
| 27%   25C    P8     6W / 180W |    284MiB /  8111MiB |      0%      Default |
+-------------------------------+----------------------+----------------------+
                                                                               
+-----------------------------------------------------------------------------+
| Processes:                                                       GPU Memory |
|  GPU       PID  Type  Process name                               Usage      |
|=============================================================================|
|    0      1078    G   /usr/lib/xorg/Xorg                             146MiB |
|    0      2170    G   /usr/bin/compiz                                136MiB |

+-----------------------------------------------------------------------------+

cudnn 5.1
https://developer.nvidia.com/rdp/cudnn-download
Download cuDNN v5.1 (August 10, 2016)
cuDNN v5.1 Library for Linux

tar xvzf cudnn-8.0-linux-x64-v5.1.tgz
sudo cp cuda/include/cudnn.h /usr/local/cuda/include
sudo cp cuda/lib64/libcudnn* /usr/local/cuda/lib64
sudo chmod a+r /usr/local/cuda/include/cudnn.h /usr/local/cuda/lib64/libcudnn*

Install Caffe
https://github.com/BVLC/caffe/wiki/Ubuntu-16.04-or-15.10-Installation-Guide

CXX src/caffe/util/db.cpp
CXX src/caffe/util/db_leveldb.cpp
CXX src/caffe/util/db_lmdb.cpp
CXX src/caffe/util/hdf5.cpp
CXX src/caffe/util/im2col.cpp
CXX src/caffe/util/insert_splits.cpp
CXX src/caffe/util/io.cpp
CXX src/caffe/util/math_functions.cpp
CXX src/caffe/util/signal_handler.cpp
CXX src/caffe/util/upgrade_proto.cpp
NVCC src/caffe/layers/absval_layer.cu
nvcc warning : The 'compute_20', 'sm_20', and 'sm_21' architectures are deprecated, and may be removed in a future release (Use -Wno-deprecated-gpu-targets to suppress warning).
In file included from /usr/local/cuda-8.0/include/cuda_runtime.h:78:0,
                 from <command-line>:0:
/usr/local/cuda-8.0/include/host_config.h:119:2: error: #error -- unsupported GNU version! gcc versions later than 5 are not supported!
 #error -- unsupported GNU version! gcc versions later than 5 are not supported!
  ^~~~~
Makefile:589: recipe for target '.build_release/cuda/src/caffe/layers/absval_layer.o' failed
make: *** [.build_release/cuda/src/caffe/layers/absval_layer.o] Error 1
 


Fix: https://github.com/BVLC/caffe/wiki/GeForce-GTX-1080,---CUDA-8.0,---Ubuntu-16.04,---Caffe

#if __GNUC__ > 5

//#error -- unsupported GNU version! gcc versions later than 5 are not supported!

#endif /* __GNUC__ > 5 */


Ubuntu 16.10 gcc version is 6.2 

Use this step to change gcc version to 5.4
https://gist.github.com/beci/2a2091f282042ed20cda

sudo add-apt-repository ppa:ubuntu-toolchain-r/test
sudo apt-get update
sudo apt-get install gcc-5 g++-5
sudo update-alternatives --install /usr/bin/gcc gcc /usr/bin/gcc-5 60 --slave /usr/bin/g++ g++ /usr/bin/g++-5

sudo update-alternatives --install /usr/bin/gcc gcc /usr/bin/gcc-5 1

$ gcc --version
gcc (Ubuntu 5.4.1-2ubuntu2) 5.4.1 20160929


$ g++ --version
g++ (Ubuntu 5.4.1-2ubuntu2) 5.4.1 20160929



Problem when running caffe runtest
[----------] 5 tests from ImageDataLayerTest/2, where TypeParam = caffe::GPUDevice<float>
[ RUN      ] ImageDataLayerTest/2.TestSpace
[       OK ] ImageDataLayerTest/2.TestSpace (32 ms)
[ RUN      ] ImageDataLayerTest/2.TestShuffle
[       OK ] ImageDataLayerTest/2.TestShuffle (104 ms)
[ RUN      ] ImageDataLayerTest/2.TestRead
[       OK ] ImageDataLayerTest/2.TestRead (104 ms)
[ RUN      ] ImageDataLayerTest/2.TestResize
*** Aborted at 1481571270 (unix time) try "date -d @1481571270" if you are using GNU date ***
PC: @     0x7fa785a370ba (unknown)
*** SIGSEGV (@0xfffffffffffffff7) received by PID 20554 (TID 0x7fa75d032700) from PID 18446744073709551607; stack trace: ***
    @     0x7fa786f1d630 (unknown)
    @     0x7fa785a370ba (unknown)
    @     0x7fa785a3718b (unknown)
    @     0x7fa785a38ce8 (unknown)
    @     0x7fa785a37692 (unknown)
    @     0x7fa785a32020 (unknown)
    @     0x7fa785a30165 tbb::internal::allocate_root_with_context_proxy::allocate()
    @     0x7fa78937ce22 cv::parallel_for_()
    @     0x7fa788c63b2a (unknown)
    @     0x7fa788c60bb7 cv::resize()
    @     0x7fa787b3a5e1 caffe::ReadImageToCVMat()
    @     0x7fa787a58550 caffe::ImageDataLayer<>::load_batch()
    @     0x7fa787a10019 caffe::BasePrefetchingDataLayer<>::InternalThreadEntry()
    @     0x7fa7879e8dbe caffe::InternalThread::entry()
    @     0x7fa7879ebd0f boost::_mfi::mf5<>::operator()()
    @     0x7fa7879ebbe7 boost::_bi::list6<>::operator()<>()
    @     0x7fa7879ebadc boost::_bi::bind_t<>::operator()()
    @     0x7fa7879eba8e boost::detail::thread_data<>::run()
    @     0x7fa788923596 (unknown)
    @     0x7fa786f136ca start_thread
    @     0x7fa786c4d0af clone
    @                0x0 (unknown)
Makefile:527: recipe for target 'runtest' failed
make: *** [runtest] Segmentation fault (core dumped)



Tried recompile protobuf verion 2.5 : https://github.com/BVLC/caffe/wiki/GeForce-GTX-1080,---CUDA-8.0,---Ubuntu-16.04,---Caffe
But it does not solve the problem.



Ubuntu 16.04 WiFi is not detected for Intel Dual BandWireless-AC 3168

Ubuntu 16.04 WiFi is not detected for Intel Dual BandWireless-AC 3168

https://bugs.launchpad.net/ubuntu/+source/linux/+bug/1627114

http://askubuntu.com/questions/827795/how-do-i-get-an-intel-wireless-3168-802-11ac-wireless-card-to-work/828614#828614

nvidia
http://askubuntu.com/questions/760934/graphics-issues-after-while-installing-ubuntu-16-04-16-10-with-nvidia-graphics

Saturday, December 3, 2016

Ansible : sphere_guest

https://github.com/ansible/ansible-modules-core/issues/2006

ansible use /Resources/<RESOURCE_NAME>

http://stackoverflow.com/questions/38736888/trouble-with-pysphere-ansible

- hosts: localhost
  tasks:
    - vsphere_guest:
         ...


Wednesday, November 30, 2016

ONTAP implementation guide

http://www.netapp.com/us/media/tr-4067.pdf

Linux: Kernel module

https://wiki.archlinux.org/index.php/Kernel_modules

RHEL 6
https://access.redhat.com/documentation/en-US/Red_Hat_Enterprise_Linux/6/html/Deployment_Guide/sec-Persistent_Module_Loading.html

https://access.redhat.com/documentation/en-US/Red_Hat_Enterprise_Linux/6/html/Deployment_Guide/sec-Setting_Module_Parameters.html


RHEL 7
https://access.redhat.com/documentation/en-US/Red_Hat_Enterprise_Linux/7/html/System_Administrators_Guide/sec-Persistent_Module_Loading.html


Saturday, November 26, 2016

Thursday, November 24, 2016

Python : with Pillow installed matplotlib can handle more images

ValueError: Only know how to handle extensions: ['png']; with Pillow installed matplotlib can handle more images

Solution : pip install pillow

Wednesday, November 16, 2016

Python : regular expression

https://regex101.com

^[1-9]\d*[G]$

^ asserts position at start of the string
Match a single character present in the list below
[1-9]
1-9 a single character in the range between 1(ASCII 49) and 9 (ASCII 57) (case sensitive)

\d*
 matches a digit (equal to [0-9])
* Quantifier — Matches between zero and unlimited times, as many times as possible, giving back as needed (greedy)
Match a single character present in the list below
[G]
G matches the character G literally (case sensitive)
$ asserts position at the end of the string

a{3}
Matches exactly 3 consecutive `a` characters

^(?!root|0).*$
cannot start with root or 0


Saturday, November 12, 2016

Caffe : draw_net.py


Ubuntu : 14.04
 
In order to run draw_net.py

sudo apt-get install cython

sudo pip install protobuf

sudo easy_install -U setuptools

sudo pip install cython –upgrade

sudo pip install matplotlib

sudo pip install scikit-image

sudo pip install pydot

sudo apt-get install GraphViz

python python/draw_net.py models/bvlc_reference_caffenet/deploy.prototxt caffenet.png

Monday, November 7, 2016

Monday, October 31, 2016

Python : validate json format

https://docs.python.org/2/library/json.html

Using json.tool from the shell to validate and pretty-print:
$ echo '{"json":"obj"}' | python -m json.tool
{
    "json": "obj"
}
$ echo '{1.2:3.4}' | python -mjson.tool
Expecting property name enclosed in double quotes: line 1 column 2 (char 1)

Saturday, October 29, 2016

Deep Learning : source code

Lots of tensor flow resources
https://github.com/jtoy/awesome-tensorflow
https://github.com/ujjwalkarn/Machine-Learning-Tutorials/blob/master/README.md

https://github.com/cysmith/neural-style-tf

https://github.com/dennybritz/reinforcement-learning

https://github.com/ibab/tensorflow-wavenet

https://github.com/buriburisuri/ebgan

https://github.com/MorvanZhou/tfnn

http://www.asimovinstitute.org/neural-network-zoo/

https://classroom.udacity.com/courses/ud730/lessons/6370362152/concepts/63798118150923#

run tensor flow on iOS
http://qiita.com/shu223/items/ce190ea6669b2636a8a7

RNN:
http://r2rt.com/styles-of-truncated-backpropagation.html



Friday, October 28, 2016

Linux : bootup

man 7 bootup

https://www.freedesktop.org/software/systemd/man/bootup.html


Linux : systemd

https://www.digitalocean.com/community/tutorials/how-to-use-systemctl-to-manage-systemd-services-and-units

Introduction

Systemd is an init system and system manager that is widely becoming the new standard for Linux machines. While there are considerable opinions about whether systemd is an improvement over the traditional SysV init systems it is replacing, the majority of distributions plan to adopt it or have already done so.
Due to its heavy adoption, familiarizing yourself with systemd is well worth the trouble, as it will make administrating these servers considerably easier. Learning about and utilizing the tools and daemons that comprise systemd will help you better appreciate the power, flexibility, and capabilities it provides, or at least help you to do your job with minimal hassle.
In this guide, we will be discussing the systemctl command, which is the central management tool for controlling the init system. We will cover how to manage services, check statuses, change system states, and work with the configuration files.

Service Management

The fundamental purpose of an init system is to initialize the components that must be started after the Linux kernel is booted (traditionally known as "userland" components). The init system is also used to manage services and daemons for the server at any point while the system is running. With that in mind, we will start with some simple service management operations.
In systemd, the target of most actions are "units", which are resources that systemd knows how to manage. Units are categorized by the type of resource they represent and they are defined with files known as unit files. The type of each unit can be inferred from the suffix on the end of the file.
For service management tasks, the target unit will be service units, which have unit files with a suffix of .service. However, for most service management commands, you can actually leave off the .servicesuffix, as systemd is smart enough to know that you probably want to operate on a service when using service management commands.

Starting and Stopping Services

To start a systemd service, executing instructions in the service's unit file, use the start command. If you are running as a non-root user, you will have to use sudo since this will affect the state of the operating system:
sudo systemctl start application.service
As we mentioned above, systemd knows to look for *.service files for service management commands, so the command could just as easily be typed like this:
sudo systemctl start application
Although you may use the above format for general administration, for clarity, we will use the .servicesuffix for the remainder of the commands to be explicit about the target we are operating on.
To stop a currently running service, you can use the stop command instead:
sudo systemctl stop application.service

Restarting and Reloading

To restart a running service, you can use the restart command:
sudo systemctl restart application.service
If the application in question is able to reload its configuration files (without restarting), you can issue the reload command to initiate that process:
sudo systemctl reload application.service
If you are unsure whether the service has the functionality to reload its configuration, you can issue the reload-or-restart command. This will reload the configuration in-place if available. Otherwise, it will restart the service so the new configuration is picked up:
sudo systemctl reload-or-restart application.service

Enabling and Disabling Services

The above commands are useful for starting or stopping commands during the current session. To tell systemd to start services automatically at boot, you must enable them.
To start a service at boot, use the enable command:
sudo systemctl enable application.service
This will create a symbolic link from the system's copy of the service file (usually in /lib/systemd/system or /etc/systemd/system) into the location on disk where systemd looks for autostart files (usually /etc/systemd/system/some_target.target.wants. We will go over what a target is later in this guide).
To disable the service from starting automatically, you can type:
sudo systemctl disable application.service
This will remove the symbolic link that indicated that the service should be started automatically.
Keep in mind that enabling a service does not start it in the current session. If you wish to start the service and enable it at boot, you will have to issue both the start and enable commands.

Checking the Status of Services

To check the status of a service on your system, you can use the status command:
systemctl status application.service
This will provide you with the service state, the cgroup hierarchy, and the first few log lines.
For instance, when checking the status of an Nginx server, you may see output like this:
● nginx.service - A high performance web server and a reverse proxy server
   Loaded: loaded (/usr/lib/systemd/system/nginx.service; enabled; vendor preset: disabled)
   Active: active (running) since Tue 2015-01-27 19:41:23 EST; 22h ago
 Main PID: 495 (nginx)
   CGroup: /system.slice/nginx.service
           ├─495 nginx: master process /usr/bin/nginx -g pid /run/nginx.pid; error_log stderr;
           └─496 nginx: worker process

Jan 27 19:41:23 desktop systemd[1]: Starting A high performance web server and a reverse proxy server...
Jan 27 19:41:23 desktop systemd[1]: Started A high performance web server and a reverse proxy server.
This gives you a nice overview of the current status of the application, notifying you of any problems and any actions that may be required.
There are also methods for checking for specific states. For instance, to check to see if a unit is currently active (running), you can use the is-active command:
systemctl is-active application.service
This will return the current unit state, which is usually active or inactive. The exit code will be "0" if it is active, making the result simpler to parse programatically.
To see if the unit is enabled, you can use the is-enabled command:
systemctl is-enabled application.service
This will output whether the service is enabled or disabled and will again set the exit code to "0" or "1" depending on the answer to the command question.
A third check is whether the unit is in a failed state. This indicates that there was a problem starting the unit in question:
systemctl is-failed application.service
This will return active if it is running properly or failed if an error occurred. If the unit was intentionally stopped, it may return unknown or inactive. An exit status of "0" indicates that a failure occurred and an exit status of "1" indicates any other status.

System State Overview

The commands so far have been useful for managing single services, but they are not very helpful for exploring the current state of the system. There are a number of systemctl commands that provide this information.

Listing Current Units

To see a list of all of the active units that systemd knows about, we can use the list-units command:
systemctl list-units
This will show you a list of all of the units that systemd currently has active on the system. The output will look something like this:
UNIT                                      LOAD   ACTIVE SUB     DESCRIPTION
atd.service                               loaded active running ATD daemon
avahi-daemon.service                      loaded active running Avahi mDNS/DNS-SD Stack
dbus.service                              loaded active running D-Bus System Message Bus
dcron.service                             loaded active running Periodic Command Scheduler
dkms.service                              loaded active exited  Dynamic Kernel Modules System
getty@tty1.service                        loaded active running Getty on tty1

. . .
The output has the following columns:
  • UNIT: The systemd unit name
  • LOAD: Whether the unit's configuration has been parsed by systemd. The configuration of loaded units is kept in memory.
  • ACTIVE: A summary state about whether the unit is active. This is usually a fairly basic way to tell if the unit has started successfully or not.
  • SUB: This is a lower-level state that indicates more detailed information about the unit. This often varies by unit type, state, and the actual method in which the unit runs.
  • DESCRIPTION: A short textual description of what the unit is/does.
Since the list-units command shows only active units by default, all of the entries above will show "loaded" in the LOAD column and "active" in the ACTIVE column. This display is actually the default behavior of systemctl when called without additional commands, so you will see the same thing if you call systemctl with no arguments:
systemctl
We can tell systemctl to output different information by adding additional flags. For instance, to see all of the units that systemd has loaded (or attempted to load), regardless of whether they are currently active, you can use the --all flag, like this:
systemctl list-units --all
This will show any unit that systemd loaded or attempted to load, regardless of its current state on the system. Some units become inactive after running, and some units that systemd attempted to load may have not been found on disk.
You can use other flags to filter these results. For example, we can use the --state= flag to indicate the LOAD, ACTIVE, or SUB states that we wish to see. You will have to keep the --all flag so that systemctl allows non-active units to be displayed:
systemctl list-units --all --state=inactive
Another common filter is the --type= filter. We can tell systemctl to only display units of the type we are interested in. For example, to see only active service units, we can use:
systemctl list-units --type=service

Listing All Unit Files

The list-units command only displays units that systemd has attempted to parse and load into memory. Since systemd will only read units that it thinks it needs, this will not necessarily include all of the available units on the system. To see every available unit file within the systemd paths, including those that systemd has not attempted to load, you can use the list-unit-files command instead:
systemctl list-unit-files
Units are representations of resources that systemd knows about. Since systemd has not necessarily read all of the unit definitions in this view, it only presents information about the files themselves. The output has two columns: the unit file and the state.
UNIT FILE                                  STATE   
proc-sys-fs-binfmt_misc.automount          static  
dev-hugepages.mount                        static  
dev-mqueue.mount                           static  
proc-fs-nfsd.mount                         static  
proc-sys-fs-binfmt_misc.mount              static  
sys-fs-fuse-connections.mount              static  
sys-kernel-config.mount                    static  
sys-kernel-debug.mount                     static  
tmp.mount                                  static  
var-lib-nfs-rpc_pipefs.mount               static  
org.cups.cupsd.path                        enabled

. . .
The state will usually be "enabled", "disabled", "static", or "masked". In this context, static means that the unit file does not contain an "install" section, which is used to enable a unit. As such, these units cannot be enabled. Usually, this means that the unit performs a one-off action or is used only as a dependency of another unit and should not be run by itself.
We will cover what "masked" means momentarily.

Unit Management

So far, we have been working with services and displaying information about the unit and unit files that systemd knows about. However, we can find out more specific information about units using some additional commands.

Displaying a Unit File

To display the unit file that systemd has loaded into its system, you can use the cat command (this was added in systemd version 209). For instance, to see the unit file of the atd scheduling daemon, we could type:
systemctl cat atd.service
[Unit]
Description=ATD daemon

[Service]
Type=forking
ExecStart=/usr/bin/atd

[Install]
WantedBy=multi-user.target
The output is the unit file as known to the currently running systemd process. This can be important if you have modified unit files recently or if you are overriding certain options in a unit file fragment (we will cover this later).

Displaying Dependencies

To see a unit's dependency tree, you can use the list-dependencies command:
systemctl list-dependencies sshd.service
This will display a hierarchy mapping the dependencies that must be dealt with in order to start the unit in question. Dependencies, in this context, include those units that are either required by or wanted by the units above it.
sshd.service
├─system.slice
└─basic.target
  ├─microcode.service
  ├─rhel-autorelabel-mark.service
  ├─rhel-autorelabel.service
  ├─rhel-configure.service
  ├─rhel-dmesg.service
  ├─rhel-loadmodules.service
  ├─paths.target
  ├─slices.target

. . .
The recursive dependencies are only displayed for .target units, which indicate system states. To recursively list all dependencies, include the --all flag. 
To show reverse dependencies (units that depend on the specified unit), you can add the --reverse flag to the command. Other flags that are useful are the --before and --after flags, which can be used to show units that depend on the specified unit starting before and after themselves, respectively.

Checking Unit Properties

To see the low-level properties of a unit, you can use the show command. This will display a list of properties that are set for the specified unit using a key=value format:
systemctl show sshd.service
Id=sshd.service
Names=sshd.service
Requires=basic.target
Wants=system.slice
WantedBy=multi-user.target
Conflicts=shutdown.target
Before=shutdown.target multi-user.target
After=syslog.target network.target auditd.service systemd-journald.socket basic.target system.slice
Description=OpenSSH server daemon

. . .
If you want to display a single property, you can pass the -p flag with the property name. For instance, to see the conflicts that the sshd.service unit has, you can type:
systemctl show sshd.service -p Conflicts
Conflicts=shutdown.target

Masking and Unmasking Units

We saw in the service management section how to stop or disable a service, but systemd also has the ability to mark a unit as completely unstartable, automatically or manually, by linking it to /dev/null. This is called masking the unit, and is possible with the mask command:
sudo systemctl mask nginx.service
This will prevent the Nginx service from being started, automatically or manually, for as long as it is masked.
If you check the list-unit-files, you will see the service is now listed as masked:
systemctl list-unit-files
. . .

kmod-static-nodes.service              static  
ldconfig.service                       static  
mandb.service                          static  
messagebus.service                     static  
nginx.service                          masked
quotaon.service                        static  
rc-local.service                       static  
rdisc.service                          disabled
rescue.service                         static

. . .
If you attempt to start the service, you will see a message like this:
sudo systemctl start nginx.service
Failed to start nginx.service: Unit nginx.service is masked.
To unmask a unit, making it available for use again, simply use the unmask command:
sudo systemctl unmask nginx.service
This will return the unit to its previous state, allowing it to be started or enabled.

Editing Unit Files

While the specific format for unit files is outside of the scope of this tutorial, systemctl provides builtin mechanisms for editing and modifying unit files if you need to make adjustments. This functionality was added in systemd version 218.
The edit command, by default, will open a unit file snippet for the unit in question:
sudo systemctl edit nginx.service
This will be a blank file that can be used to override or add directives to the unit definition. A directory will be created within the /etc/systemd/system directory which contains the name of the unit with .dappended. For instance, for the nginx.service, a directory called nginx.service.d will be created.
Within this directory, a snippet will be created called override.conf. When the unit is loaded, systemdwill, in memory, merge the override snippet with the full unit file. The snippet's directives will take precedence over those found in the original unit file. 
If you wish to edit the full unit file instead of creating a snippet, you can pass the --full flag:
sudo systemctl edit --full nginx.service
This will load the current unit file into the editor, where it can be modified. When the editor exits, the changed file will be written to /etc/systemd/system, which will take precedence over the system's unit definition (usually found somewhere in /lib/systemd/system).
To remove any additions you have made, either delete the unit's .d configuration directory or the modified service file from /etc/systemd/system. For instance, to remove a snippet, we could type:
sudo rm -r /etc/systemd/system/nginx.service.d
To remove a full modified unit file, we would type:
sudo rm /etc/systemd/system/nginx.service
After deleting the file or directory, you should reload the systemd process so that it no longer attempts to reference these files and reverts back to using the system copies. You can do this by typing:
sudo systemctl daemon-reload

Adjusting the System State (Runlevel) with Targets

Targets are special unit files that describe a system state or synchronization point. Like other units, the files that define targets can be identified by their suffix, which in this case is .target. Targets do not do much themselves, but are instead used to group other units together.
This can be used in order to bring the system to certain states, much like other init systems use runlevels. They are used as a reference for when certain functions are available, allowing you to specify the desired state instead of the individual units needed to produce that state.
For instance, there is a swap.target that is used to indicate that swap is ready for use. Units that are part of this process can sync with this target by indicating in their configuration that they are WantedBy=or RequiredBy= the swap.target. Units that require swap to be available can specify this condition using the Wants=Requires=, and After= specifications to indicate the nature of their relationship.

Getting and Setting the Default Target

The systemd process has a default target that it uses when booting the system. Satisfying the cascade of dependencies from that single target will bring the system into the desired state. To find the default target for your system, type:
systemctl get-default
multi-user.target
If you wish to set a different default target, you can use the set-default. For instance, if you have a graphical desktop installed and you wish for the system to boot into that by default, you can change your default target accordingly:
sudo systemctl set-default graphical.target

Listing Available Targets

You can get a list of the available targets on your system by typing:
systemctl list-unit-files --type=target
Unlike runlevels, multiple targets can be active at one time. An active target indicates that systemd has attempted to start all of the units tied to the target and has not tried to tear them down again. To see all of the active targets, type:
systemctl list-units --type=target

Isolating Targets

It is possible to start all of the units associated with a target and stop all units that are not part of the dependency tree. The command that we need to do this is called, appropriately, isolate. This is similar to changing the runlevel in other init systems.
For instance, if you are operating in a graphical environment with graphical.target active, you can shut down the graphical system and put the system into a multi-user command line state by isolating the multi-user.target. Since graphical.target depends on multi-user.target but not the other way around, all of the graphical units will be stopped.
You may wish to take a look at the dependencies of the target you are isolating before performing this procedure to ensure that you are not stopping vital services:
systemctl list-dependencies multi-user.target
When you are satisfied with the units that will be kept alive, you can isolate the target by typing:
sudo systemctl isolate multi-user.target

Using Shortcuts for Important Events

There are targets defined for important events like powering off or rebooting. However, systemctl also has some shortcuts that add a bit of additional functionality.
For instance, to put the system into rescue (single-user) mode, you can just use the rescue command instead of isolate rescue.target:
sudo systemctl rescue
This will provide the additional functionality of alerting all logged in users about the event.
To halt the system, you can use the halt command:
sudo systemctl halt
To initiate a full shutdown, you can use the poweroff command:
sudo systemctl poweroff
A restart can be started with the reboot command:
sudo systemctl reboot
These all alert logged in users that the event is occurring, something that simply running or isolating the target will not do. Note that most machines will link the shorter, more conventional commands for these operations so that they work properly with systemd.
For example, to reboot the system, you can usually type:
sudo reboot

Conclusion

By now, you should be familiar with some of the basic capabilities of the systemctl command that allow you to interact with and control your systemd instance. The systemctl utility will be your main point of interaction for service and system state management.
While systemctl operates mainly with the core systemd process, there are other components to the systemd ecosystem that are controlled by other utilities. Other capabilities, like log management and user sessions are handled by separate daemons and management utilities (journald/journalctl and logind/loginctl respectively). Taking time to become familiar with these other tools and daemons will make management an easier task.