Thursday, December 27, 2018

Install VMware Workstation on Ubuntu

This blog post is of interest to people that need to install VMware Workstation on their Ubuntu system.

The goal is not to create Yet Another Blog (YAB) on this subject. There are already plenty of blogs on this subject. Unfortunately, it is rare to find blogs on performing the installation from the command line. It is even rarer to find detailed prerequisites for the installation.

It is assumed that the reader has some familiarity with Unix. This is not an unreasonable assumption because people should not be performing a command line installation of VMware Workstation unless they are familiar with Unix.

All the commands below were executed using Workstation Pro 15.0.2 on Ubuntu 18.04.01.
  1. Verify that Workstation 15.x is certified on Ubuntu 18.04
  2. Download VMware Workstation
    1. The download won't be quick because the file is over 400 MB in size.
      1. Examine the downloaded file
        rlucente@rlucente-Bonobo-WS:~/lucente_robert/vm_ware/work_station_pro_download$ ls -l 
        
        total 484052
        
        -rw-rw-r-- 1 rlucente rlucente 495664015 Nov 30 15:37 VMware-Workstation-Full-15.0.2-10952284.x86_64.bundle
        
        
      2. Prepare environment for VMware Workstation
        1. Preliminaries
          1. Update operating sytem
            1. Command: sudo apt-get update
              1. Output of Command
                rlucente@rlucente-Bonobo-WS:~$ sudo apt-get update
                [sudo] password for rlucente: 
                
                Hit:1 http://us.archive.ubuntu.com/ubuntu bionic InRelease
                
                Get:2 http://us.archive.ubuntu.com/ubuntu bionic-updates InRelease [88.7 kB]
                
                Hit:3 http://ppa.launchpad.net/system76-dev/stable/ubuntu bionic InRelease
                
                Get:4 http://security.ubuntu.com/ubuntu bionic-security InRelease [83.2 kB]
                
                Get:5 http://us.archive.ubuntu.com/ubuntu bionic-backports InRelease [74.6 kB]
                
                Fetched 247 kB in 1s (256 kB/s)
                
                Reading package lists... Done
                
                
              2. Command: sudo apt-get dist-upgrade
                1. Output of Command
                  rlucente@rlucente-Bonobo-WS:~$ sudo apt-get dist-upgrade
                  
                  Reading package lists... Done
                  
                  Building dependency tree  
                  
                  Reading state information... Done
                  
                  Calculating upgrade... Done
                  
                  The following packages were automatically installed and are no longer required:
                  
                    libnvidia-cfg1-396 libnvidia-common-396 libnvidia-compute-396
                  
                    libnvidia-compute-396:i386 libnvidia-decode-396 libnvidia-decode-396:i386
                  
                    libnvidia-encode-396 libnvidia-encode-396:i386 libnvidia-fbc1-396
                  
                    libnvidia-fbc1-396:i386 libnvidia-gl-396 libnvidia-gl-396:i386
                  
                    libnvidia-ifr1-396 libnvidia-ifr1-396:i386 nvidia-compute-utils-396
                  
                    nvidia-dkms-396 nvidia-driver-396 nvidia-utils-396
                  
                    xserver-xorg-video-nvidia-396
                  
                  Use 'sudo apt autoremove' to remove them.
                  
                  The following packages will be upgraded:
                  
                    python3-update-manager unattended-upgrades update-manager
                  
                    update-manager-core
                  
                  4 upgraded, 0 newly installed, 0 to remove and 0 not upgraded.
                  
                  Need to get 632 kB of archives.
                  
                  After this operation, 1,024 B of additional disk space will be used.
                  
                  Do you want to continue? [Y/n] Y
                  
                  Get:1 http://us.archive.ubuntu.com/ubuntu bionic-updates/main amd64 python3-update-manager all 1:18.04.11.7 [35.0 kB]
                  
                  Get:2 http://us.archive.ubuntu.com/ubuntu bionic-updates/main amd64 update-manager-core all 1:18.04.11.7 [8,484 B]
                  
                  Get:3 http://us.archive.ubuntu.com/ubuntu bionic-updates/main amd64 update-manager all 1:18.04.11.7 [551 kB]
                  
                  Get:4 http://us.archive.ubuntu.com/ubuntu bionic-updates/main amd64 unattended-upgrades all 1.1ubuntu1.18.04.6 [37.7 kB]
                  
                  Fetched 632 kB in 2s (415 kB/s)
                  
                  Preconfiguring packages ...
                  
                  (Reading database ... 170931 files and directories currently installed.)
                  
                  Preparing to unpack .../python3-update-manager_1%3a18.04.11.7_all.deb ...
                  
                  Unpacking python3-update-manager (1:18.04.11.7) over (1:18.04.11.6) ...
                  
                  Preparing to unpack .../update-manager-core_1%3a18.04.11.7_all.deb ...
                  
                  Unpacking update-manager-core (1:18.04.11.7) over (1:18.04.11.6) ...
                  
                  Preparing to unpack .../update-manager_1%3a18.04.11.7_all.deb ...
                  
                  Unpacking update-manager (1:18.04.11.7) over (1:18.04.11.6) ...
                  
                  Preparing to unpack .../unattended-upgrades_1.1ubuntu1.18.04.6_all.deb ...
                  
                  Unpacking unattended-upgrades (1.1ubuntu1.18.04.6) over (1.1ubuntu1) ...
                  
                  Processing triggers for mime-support (3.60ubuntu1) ...
                  
                  Processing triggers for ureadahead (0.100.0-20) ...
                  
                  ureadahead will be reprofiled on next reboot
                  
                  Processing triggers for desktop-file-utils (0.23-1ubuntu3.18.04.2) ...
                  
                  Processing triggers for libglib2.0-0:amd64 (2.56.3-0ubuntu0.18.04.1) ...
                  
                  Setting up python3-update-manager (1:18.04.11.7) ...
                  
                  Processing triggers for systemd (237-3ubuntu10.9) ...
                  
                  Setting up unattended-upgrades (1.1ubuntu1.18.04.6) ...
                  
                  Replacing config file /etc/apt/apt.conf.d/50unattended-upgrades with new version
                  
                  Processing triggers for man-db (2.8.3-2ubuntu0.1) ...
                  
                  Processing triggers for gnome-menus (3.13.3-11ubuntu1.1) ...
                  
                  Setting up update-manager-core (1:18.04.11.7) ...
                  
                  Setting up update-manager (1:18.04.11.7) ...
                  
                  
                  1. Comment
                    1. Ignore "The following packages were automatically installed and are no longer required:" because they are related to nvidia.
                2. Determine operating system version
                  1. Command: lsb_release -a
                    1. Output of Command
                      rlucente@rlucente-Bonobo-WS:~$ lsb_release -a No LSB modules are available.
                      Distributor ID: Ubuntu
                      Description: Ubuntu 18.04.1 LTS
                      Release: 18.04
                      Codename: bionic
                      
                      
                  2. Determine kernel release
                    1. This information is used in many places in the following steps.
                      1. Command: uname -r
                        1. Output of Command
                          rlucente@rlucente-Bonobo-WS:~$ uname -r
                          4.15.0-39-generic
                          
                          
                    2. VMware Workstation Prerequisites
                      1. Operating System Prerequisites for VMware Workstation
                        1. Real-Time Clock (RTC) Function Compiled into Kernel
                          1. Command: sudo hwclock --debug
                            1. Output of Command
                              rlucente@rlucente-Bonobo-WS:~$ sudo hwclock --debug
                              
                              hwclock from util-linux 2.31.1
                              
                              System Time: 1543604238.820144
                              
                              Trying to open: /dev/rtc0
                              
                              Using the rtc interface to the clock.
                              
                              Assuming hardware clock is kept in UTC time.
                              
                              Waiting for clock tick...
                              
                              ...got clock tick
                              
                              Time read from Hardware Clock: 2018/11/30 18:57:19 
                              
                              Hw clock time : 2018/11/30 18:57:19 = 1543604239 seconds since 1969
                              
                              Time since last adjustment is 1543604239 seconds
                              
                              Calculated Hardware Clock drift is 0.000000 seconds
                              
                              2018-11-30 13:57:18.795241-0500
                              
                              
                              1. Comment
                                1. The following 2 lines indicate that RTC function is compiled into the kernel
                                  1. Trying to open: /dev/rtc0
                                    1. Using the rtc interface to the clock.
                                2. Parallel port PC-style hardware option (CONFIG_PARPORT_PC) set to m
                                  1. Content of file /boot/config-4.15.0-39-generic
                                    #
                                    # Automatically generated file; DO NOT EDIT.
                                    # Linux/x86 4.15.0-39-generic Kernel Configuration
                                    #
                                    CONFIG_64BIT=y
                                    CONFIG_X86_64=y
                                    CONFIG_X86=y
                                    
                                    ...
                                    
                                    CONFIG_ARCH_MIGHT_HAVE_PC_PARPORT=y
                                    CONFIG_PARPORT=m
                                    
                                    CONFIG_PARPORT_PC=m
                                    
                                    CONFIG_PARPORT_SERIAL=m
                                    CONFIG_PARPORT_PC_FIFO=y
                                    
                                    ...
                                    
                                    
                                  2. Swap space must be 8 GB or larger
                                    1. For the details, refer to my blog post "Increasing Swap Size on Ubuntu
                                  3. Package Prerequisites for VMware Workstation
                                    1. gcc (Gnu C compiler)
                                      1. Command: sudo apt-get install gcc
                                        1. Output of Command
                                          rlucente@rlucente-Bonobo-WS:/boot$ sudo apt-get install gcc 
                                          
                                          [sudo] password for rlucente: 
                                          
                                          Reading package lists... Done
                                          
                                          Building dependency tree       
                                          
                                          Reading state information... Done
                                          
                                          gcc is already the newest version (4:7.3.0-3ubuntu2.1).
                                          
                                          gcc set to manually installed.
                                          
                                          The following packages were automatically installed and are no longer required:
                                          
                                            libnvidia-cfg1-396 libnvidia-common-396 libnvidia-compute-396
                                          
                                            libnvidia-compute-396:i386 libnvidia-decode-396 libnvidia-decode-396:i386
                                          
                                            libnvidia-encode-396 libnvidia-encode-396:i386 libnvidia-fbc1-396
                                          
                                            libnvidia-fbc1-396:i386 libnvidia-gl-396 libnvidia-gl-396:i386
                                          
                                            libnvidia-ifr1-396 libnvidia-ifr1-396:i386 nvidia-compute-utils-396
                                          
                                            nvidia-dkms-396 nvidia-driver-396 nvidia-utils-396
                                          
                                            xserver-xorg-video-nvidia-396
                                          
                                          Use 'sudo apt autoremove' to remove them.
                                          
                                          0 upgraded, 0 newly installed, 0 to remove and 0 not upgraded.
                                          
                                          
                                        2. make (determines automatically which pieces of a program need to be re-compiled and issues the commands necessary to recompile them)
                                          1. Command: sudo apt-get install make
                                            1. Output of Command
                                              rlucente@rlucente-Bonobo-WS:/boot$ sudo apt-get install make
                                              
                                              Reading package lists... Done
                                              
                                              Building dependency tree
                                              
                                              Reading state information... Done
                                              
                                              make is already the newest version (4.1-9.1ubuntu1).
                                              
                                              make set to manually installed.
                                              
                                              The following packages were automatically installed and are no longer required:
                                              
                                                libnvidia-cfg1-396 libnvidia-common-396 libnvidia-compute-396
                                              
                                                libnvidia-compute-396:i386 libnvidia-decode-396 libnvidia-decode-396:i386
                                              
                                                libnvidia-encode-396 libnvidia-encode-396:i386 libnvidia-fbc1-396
                                              
                                                libnvidia-fbc1-396:i386 libnvidia-gl-396 libnvidia-gl-396:i386
                                              
                                                libnvidia-ifr1-396 libnvidia-ifr1-396:i386 nvidia-compute-utils-396
                                              
                                                nvidia-dkms-396 nvidia-driver-396 nvidia-utils-396
                                              
                                                xserver-xorg-video-nvidia-396
                                              
                                              Use 'sudo apt autoremove' to remove them.
                                              
                                              0 upgraded, 0 newly installed, 0 to remove and 0 not upgraded.
                                              
                                              
                                            2. linux-headers (headers act as an interface between internal kernel components and also between userspace and the kernel)
                                              1. Command: sudo apt-get install linux-headers-$(uname -r)
                                                1. Output of Command
                                                  rlucente@rlucente-Bonobo-WS:/boot$ sudo apt-get install linux-headers-$(uname -r)
                                                  
                                                  Reading package lists... Done
                                                  
                                                  Building dependency tree
                                                  
                                                  Reading state information... Done
                                                  
                                                  linux-headers-4.15.0-39-generic is already the newest version (4.15.0-39.42).
                                                  
                                                  linux-headers-4.15.0-39-generic set to manually installed.
                                                  
                                                  The following packages were automatically installed and are no longer required:
                                                  
                                                    libnvidia-cfg1-396 libnvidia-common-396 libnvidia-compute-396 libnvidia-compute-396:i386 libnvidia-decode-396 libnvidia-decode-396:i386 libnvidia-encode-396
                                                  
                                                    libnvidia-encode-396:i386 libnvidia-fbc1-396 libnvidia-fbc1-396:i386 libnvidia-gl-396 libnvidia-gl-396:i386 libnvidia-ifr1-396 libnvidia-ifr1-396:i386
                                                  
                                                    nvidia-compute-utils-396 nvidia-dkms-396 nvidia-driver-396 nvidia-utils-396 xserver-xorg-video-nvidia-396 Use 'sudo apt autoremove' to remove them.
                                                  
                                                  0 upgraded, 0 newly installed, 0 to remove and 0 not upgraded.
                                                  
                                                  
                                                2. dkms (Dynamic Kernel Module Support)
                                                  1. Dynamic Kernel Module Support (DKMS) is a program/framework that enables generating Linux kernel modules whose sources generally reside outside the kernel source tree. The concept is to have DKMS modules automatically rebuilt when a new kernel is installed.
                                                    1. Command: sudo apt-get install dkms
                                                      1. Output of Command
                                                        rlucente@rlucente-Bonobo-WS:/boot$ sudo apt-get install dkms
                                                        
                                                        Reading package lists... Done
                                                        
                                                        Building dependency tree
                                                        
                                                        Reading state information... Done
                                                        
                                                        dkms is already the newest version (2.3-3ubuntu9.2).
                                                        
                                                        dkms set to manually installed.
                                                        
                                                        The following packages were automatically installed and are no longer required:
                                                        
                                                          libnvidia-cfg1-396 libnvidia-common-396 libnvidia-compute-396 libnvidia-compute-396:i386 libnvidia-decode-396 libnvidia-decode-396:i386 libnvidia-encode-396
                                                        
                                                          libnvidia-encode-396:i386 libnvidia-fbc1-396 libnvidia-fbc1-396:i386 libnvidia-gl-396 libnvidia-gl-396:i386 libnvidia-ifr1-396 libnvidia-ifr1-396:i386
                                                        
                                                          nvidia-compute-utils-396 nvidia-dkms-396 nvidia-driver-396 nvidia-utils-396 xserver-xorg-video-nvidia-396 Use 'sudo apt autoremove' to remove them.
                                                        
                                                        0 upgraded, 0 newly installed, 0 to remove and 0 not upgraded.
                                                        
                                                        
                                                      2. build-essential (convenient way to install a basic C/C++ development environment)
                                                        1. Note that "build-essential" is singular. Some blogs make the mistake of making it plural.
                                                          1. Command: sudo apt-get install build-essential
                                                            1. Output of Command
                                                              rlucente@rlucente-Bonobo-WS:/boot$ sudo apt-get install build-essential
                                                              
                                                              Reading package lists... Done
                                                              
                                                              Building dependency tree
                                                              
                                                              Reading state information... Done
                                                              
                                                              build-essential is already the newest version (12.4ubuntu1).
                                                              
                                                              build-essential set to manually installed.
                                                              
                                                              The following packages were automatically installed and are no longer required:
                                                              
                                                                libnvidia-cfg1-396 libnvidia-common-396 libnvidia-compute-396 libnvidia-compute-396:i386 libnvidia-decode-396 libnvidia-decode-396:i386 libnvidia-encode-396
                                                              
                                                                libnvidia-encode-396:i386 libnvidia-fbc1-396 libnvidia-fbc1-396:i386 libnvidia-gl-396 libnvidia-gl-396:i386 libnvidia-ifr1-396 libnvidia-ifr1-396:i386
                                                              
                                                                nvidia-compute-utils-396 nvidia-dkms-396 nvidia-driver-396 nvidia-utils-396 xserver-xorg-video-nvidia-396 Use 'sudo apt autoremove' to remove them.
                                                              
                                                              0 upgraded, 0 newly installed, 0 to remove and 0 not upgraded.
                                                              
                                                              
                                                            2. libaio1 (Linux kernel Asynchronous I/O [AIO] library)
                                                              1. library enables userspace to use Linux kernel asynchronous I/O system calls, important for the performance of databases and other advanced applications.
                                                                1. Command: sudo apt-get install libaio1
                                                                  1. Output of Command
                                                                    $ sudo apt-get install libaio1
                                                                    
                                                                    Reading package lists... Done
                                                                    
                                                                    Building dependency tree
                                                                    
                                                                    Reading state information... Done
                                                                    
                                                                    The following packages were automatically installed and are no longer required:
                                                                    
                                                                      libnvidia-cfg1-396 libnvidia-common-396 libnvidia-compute-396 libnvidia-compute-396:i386 libnvidia-decode-396
                                                                    
                                                                      libnvidia-decode-396:i386 libnvidia-encode-396 libnvidia-encode-396:i386 libnvidia-fbc1-396
                                                                    
                                                                      libnvidia-fbc1-396:i386 libnvidia-gl-396 libnvidia-gl-396:i386 libnvidia-ifr1-396 libnvidia-ifr1-396:i386
                                                                    
                                                                      nvidia-compute-utils-396 nvidia-dkms-396 nvidia-driver-396 nvidia-utils-396 xserver-xorg-video-nvidia-396 Use 'sudo apt autoremove' to remove them.
                                                                    
                                                                    The following NEW packages will be installed:
                                                                    
                                                                      libaio1
                                                                    
                                                                    0 upgraded, 1 newly installed, 0 to remove and 0 not upgraded.
                                                                    
                                                                    Need to get 6,448 B of archives.
                                                                    
                                                                    After this operation, 30.7 kB of additional disk space will be used.
                                                                    
                                                                    Get:1 http://us.archive.ubuntu.com/ubuntu bionic/main amd64 libaio1 amd64 0.3.110-5 [6,448 B]
                                                                    
                                                                    Fetched 6,448 B in 0s (53.2 kB/s)
                                                                    
                                                                    Selecting previously unselected package libaio1:amd64.
                                                                    
                                                                    (Reading database ... 170931 files and directories currently installed.)
                                                                    
                                                                    Preparing to unpack .../libaio1_0.3.110-5_amd64.deb ...
                                                                    
                                                                    Unpacking libaio1:amd64 (0.3.110-5) ...
                                                                    
                                                                    Processing triggers for libc-bin (2.27-3ubuntu1) ...
                                                                    
                                                                    Setting up libaio1:amd64 (0.3.110-5) ...
                                                                    
                                                                    Processing triggers for libc-bin (2.27-3ubuntu1) ...
                                                                    
                                                                    
                                                              2. Create directories to house virtual machines
                                                                1. /home/rlucente/lucente_robert/vmware/virtual_machines/<Virtual Machine Names>
                                                              3. Install VMware Workstation
                                                                1. Make bundle installer executable
                                                                  rlucente@rlucente-Bonobo-WS:~/lucente_robert/vm_ware/work_station_pro_download$ chmod +x *bundle 
                                                                  
                                                                  
                                                                  1. Determine options of bundle installer
                                                                    1. Command & Output of Command
                                                                      rlucente@rlucente-Bonobo-WS:~/lucente_robert/vm_ware/work_station_pro_download$ ./VMware-Workstation-Full-15.0.2-10952284.x86_64.bundle --help 
                                                                      
                                                                      Extracting VMware Installer...done.
                                                                      
                                                                      [AppLoader] Use shipped Linux kernel AIO access library.
                                                                      
                                                                      An up-to-date "libaio" or "libaio1" package from your system is preferred.
                                                                      
                                                                      Usage: vmware-installer [options]
                                                                      
                                                                      VMware Installer
                                                                      
                                                                      Options:
                                                                      
                                                                        --version             show program's version number and exit
                                                                      
                                                                        -h, --help            show this help message and exit
                                                                      
                                                                        Manage:
                                                                      
                                                                          Install or uninstall products
                                                                      
                                                                          -i FILE, --install-bundle=FILE
                                                                      
                                                                                              Install bundle from FILE
                                                                      
                                                                          --install-component=FILE
                                                                      
                                                                                              Install a component
                                                                      
                                                                          --uninstall-component=NAME
                                                                      
                                                                                              Force uninstallation of a component
                                                                      
                                                                          -u NAME, --uninstall-product=NAME
                                                                      
                                                                                              Uninstall a product
                                                                      
                                                                          -r, --resolve-system
                                                                      
                                                                                              Force the system to resolve the current state
                                                                      
                                                                          --register-file=COMPONENT_NAME (config|regular) FILE
                                                                      
                                                                                              Register a file in the database
                                                                      
                                                                          -x DIR, --extract=DIR
                                                                      
                                                                                              Extract the contents of the bundle into DIR
                                                                      
                                                                          -p DIR, --prefix=DIR
                                                                      
                                                                                              Set a custom install location
                                                                      
                                                                        Information:
                                                                      
                                                                          Look up information on installed products
                                                                      
                                                                          -l, --list-products
                                                                      
                                                                                              List installed products
                                                                      
                                                                          -t, --list-components
                                                                      
                                                                                              List the installed components
                                                                      
                                                                          -L COMPONENT, --list-files=COMPONENT
                                                                      
                                                                                              List files for a given component
                                                                      
                                                                          -S FILE, --find-file=FILE
                                                                      
                                                                                              List components and files matching the given pattern
                                                                      
                                                                        Settings:
                                                                      
                                                                          Set and retrieve settings
                                                                      
                                                                          -g COMPONENT KEY, --get-setting=COMPONENT KEY
                                                                      
                                                                                              Get setting
                                                                      
                                                                          -s COMPONENT KEY VALUE, --set-setting=COMPONENT KEY VALUE
                                                                      
                                                                                              Set setting
                                                                      
                                                                          -d COMPONENT KEY, --delete-setting=COMPONENT KEY
                                                                      
                                                                                              Delete setting
                                                                      
                                                                        Options:
                                                                      
                                                                          --gtk               Use the Gtk+ UI (Default)
                                                                      
                                                                          --console           Use the console UI
                                                                      
                                                                          --custom            Allow customization of the install, including file
                                                                                              locations.
                                                                      
                                                                          --regular           Displays questions that have no good defaults
                                                                                              (Default)
                                                                      
                                                                          --required          Displays only questions absolutely required
                                                                      
                                                                          -I, --ignore-errors
                                                                      
                                                                                              Ignore component script errors
                                                                      
                                                                          --eulas-agreed      Agree to the EULA
                                                                      
                                                                      rlucente@rlucente-Bonobo-WS:~/lucente_robert/vm_ware/work_station_pro_download$ 
                                                                      
                                                                      
                                                                    2. Start VMware Workstation installer in console (non-gui) and custom modes
                                                                      1. Command: sudo ./VMware-Workstation-Full-15.0.2-10952284.x86_64.bundle --console --custom
                                                                        1. Output of Command
                                                                          Extracting VMware Installer...done.
                                                                          
                                                                          
                                                                        2. Question Before Intallation
                                                                          1. End User License Agreement
                                                                            1. Hit the letter "q" and type "yes" to the prompt that shows up
                                                                              Do you agree? [yes/no]: yes
                                                                              
                                                                              
                                                                            2. VMware OVF Tool component
                                                                              1. Screen Output
                                                                                You must accept the VMware OVF Tool component for Linux End User
                                                                                License Agreement to continue.  Press Enter to proceed.
                                                                                
                                                                                
                                                                                1. Hit the letter "q" and type "yes" to the prompt that shows up
                                                                                  Do you agree? [yes/no]: yes
                                                                                  
                                                                                  
                                                                                2. Product installation path prefix
                                                                                  1. Screen Output
                                                                                    Product installation path prefix. (Desktop integration files, such as
                                                                                    icons and .desktop entries, will still be installed under /usr.)
                                                                                    [/usr]: 
                                                                                    
                                                                                    
                                                                                  2. System service runlevel directory
                                                                                    1. Screen Output
                                                                                      System service runlevel directory (contains rc?.d directories).  Use
                                                                                      an empty directory if your system does not support rc?.d style
                                                                                      directories. [/etc]: 
                                                                                      
                                                                                      
                                                                                    2. System service scripts directory
                                                                                      1. Screen Output
                                                                                        System service scripts directory (commonly /etc/init.d). [/etc/init.d]: 
                                                                                        
                                                                                        
                                                                                      2. Shortcuts for desktop
                                                                                        1. Screen Output
                                                                                          Do you want to install shortcuts for your desktop? [yes]: yes
                                                                                          
                                                                                          
                                                                                        2. Check for product updates on startup?
                                                                                          1. Screen Output
                                                                                            Would you like to check for product updates on startup? [yes]: yes
                                                                                            
                                                                                            
                                                                                          2. Customer Experience Improvement Program ("CEIP")
                                                                                            1. Screen Output
                                                                                              VMware's Customer Experience Improvement Program ("CEIP") ... [yes]: yes
                                                                                              
                                                                                              
                                                                                            2. User that will initially connect to Workstation Server
                                                                                              1. Screen Output
                                                                                                Please enter the user that will initially connect to Workstation
                                                                                                Server. Without setting this correctly, you will not be able to share
                                                                                                VMs with other users. Additional users and administrators can be
                                                                                                configured later in Workstation by selecting "Shared VMs" and clicking
                                                                                                "Permissions".  [rlucente]: 
                                                                                                
                                                                                                
                                                                                              2. Directory for shared virtual machines
                                                                                                1. Screen Output
                                                                                                  Please choose a directory for your shared virtual machines.
                                                                                                  [/var/lib/vmware/Shared VMs]: 
                                                                                                  
                                                                                                  
                                                                                                2. Port for https access to Workstation Server
                                                                                                  1. Screen Output
                                                                                                    Please enter the port to use for https access to Workstation Server.
                                                                                                    (HTTPS port:) [443]: 
                                                                                                    
                                                                                                    
                                                                                                  2. License key
                                                                                                    1. Screen Output
                                                                                                      Enter license key. (optional) You can enter this information later.: xxx
                                                                                                      
                                                                                                      
                                                                                                  3. Product ready to be installed / Begin Installation / Complete Installation
                                                                                                    1. Screen Output
                                                                                                      The product is ready to be installed.  Press Enter to begin
                                                                                                      installation or Ctrl-C to cancel.
                                                                                                      
                                                                                                      Installing VMware VMX 15.0.2
                                                                                                          Configuring...
                                                                                                      
                                                                                                      Installing VMware Workstation 15.0.2
                                                                                                          Configuring...
                                                                                                      [######################################################################] 100%
                                                                                                      Installation was successful.
                                                                                                      
                                                                                                      
                                                                                                  4. Start Workstation from a Terminal Window
                                                                                                    1. Command: sudo vmware
                                                                                                    2. Upgrade virtual machines from version 14 to 15
                                                                                                      1. Upgrade VMware Tools on virtual machines

                                                                                                        Saturday, December 22, 2018

                                                                                                        Increasing Swap Size on Ubuntu

                                                                                                        Some of the blogs on increasing swap size on Ubuntu provide incorrect information. For example, some blogs suggest using fallocate which will not work for certain file systems. For the details on which file systems fallocate does and does not work on, refer to the swapon/swapoff man page. We avoid this complexity by using dd.

                                                                                                        There are many potential scenarios. In this particular case, swap is initially configured to 2 GB and we want to increase it to 16 GB.


                                                                                                        All the commands below were executed on Ubuntu 18.04 LTS


                                                                                                        1. Check Ubuntu version
                                                                                                          1. Command: lsb_release -a
                                                                                                            1. Output
                                                                                                              No LSB modules are available.
                                                                                                              Distributor ID: Ubuntu
                                                                                                              Description:    Ubuntu 18.04.1 LTS
                                                                                                              Release:        18.04
                                                                                                              Codename:       bionic
                                                                                                              
                                                                                                            2. Check swap configuration
                                                                                                              1. Command: sudo swapon --show --bytes
                                                                                                                1. Output
                                                                                                                  NAME      TYPE       SIZE USED PRIO
                                                                                                                  /swapfile file 2147479552    0   -2
                                                                                                                  
                                                                                                                  
                                                                                                                  1. Comment
                                                                                                                    1. The size of 2,147,479,552 bytes is close to but does not exactly correspond to 2 GB (2,147,483,648). The option "--bytes" was used to illustrate that there will be differences and that should not be surprised by this. The discrepancy is so small that you should not worry about it. An explanation for the discrepancy is beyond the scope of this blog.
                                                                                                                  2. Examine the metadata of the swap file
                                                                                                                    1. Command: ls -lh /swapfile
                                                                                                                      1. Output
                                                                                                                        -rw------- 1 root root 2.0G Oct 18 18:55 /swapfile
                                                                                                                        
                                                                                                                        1. Comments
                                                                                                                          1. Root should be the only user that can read/write to the swapfile. The above output confirms that this is happening.
                                                                                                                            1. Notice that the size of the swapfile is displayed as "2.0G".
                                                                                                                          2. Disable swap file
                                                                                                                            1. Command: sudo swapoff /swapfile
                                                                                                                              1. Output: None
                                                                                                                              2. Check swap configuration
                                                                                                                                1. Command: sudo swapon --show --bytes
                                                                                                                                  1. Output: None
                                                                                                                                  2. Add 14 GB to the existing swap file
                                                                                                                                    1. Command: sudo dd if=/dev/zero of=/swapfile bs=1M count=14336 oflag=append conv=nocreat,notrunc,fsync status=progress
                                                                                                                                    2. Output
                                                                                                                                      14579400704 bytes (15 GB, 14 GiB) copied, 5 s, 2.9 GB/s 
                                                                                                                                      14336+0 records in
                                                                                                                                      14336+0 records out
                                                                                                                                      15032385536 bytes (15 GB, 14 GiB) copied, 8.94244 s, 1.7 GB/s
                                                                                                                                      
                                                                                                                                      1. Comments
                                                                                                                                        1. Since the number of input bytes is 1M, need the count to be 14,336 (14 * 1,024).
                                                                                                                                          1. Used fsync to make sure that physically wrote output file as well as its associated metadata before finishing.
                                                                                                                                        2. Examine the metadata of the swap file
                                                                                                                                          1. Command: ls -lh /swapfile
                                                                                                                                            1. Output
                                                                                                                                              -rw------- 1 root root 16G Dec 22 15:44 /swapfile
                                                                                                                                              
                                                                                                                                              1. Comment
                                                                                                                                                1. Confirmed that the final swapfile size is 16 GB.
                                                                                                                                              2. Make swapfile usable
                                                                                                                                                1. Command: sudo mkswap --check /swapfile
                                                                                                                                                  1. Output
                                                                                                                                                    mkswap: warning: checking bad blocks from swap file is not supported: /swapfile
                                                                                                                                                    mkswap: /swapfile: warning: wiping old swap signature.
                                                                                                                                                    Setting up swapspace version 1, size = 16 GiB (17179865088 bytes)
                                                                                                                                                    no label, UUID=9ec7f376-65ab-44f0-b40b-31b8e725f3b6
                                                                                                                                                    
                                                                                                                                                    1. Comments
                                                                                                                                                      1. Don't worry about the warning "checking bad blocks from swap file is not supported". This is because the check can only be performed on block devices. In this particular case, the swapfile is not a block device.
                                                                                                                                                        1. The size of 17,179,865,088 bytes is close to but does not exactly corresponds to 16 GB (17,179,869,184). As stated previously, the discrepancy is so small that you should not worry about it.
                                                                                                                                                      2. Enable swaping
                                                                                                                                                        1. Command: sudo swapon --verbose /swapfile
                                                                                                                                                          1. Output
                                                                                                                                                            swapon: /swapfile: found signature [pagesize=4096, signature=swap]
                                                                                                                                                            swapon: /swapfile: pagesize=4096, swapsize=17179869184, devsize=17179869184
                                                                                                                                                            
                                                                                                                                                            1. Comment
                                                                                                                                                              1. The size of 17,179,869,184 bytes corresponds exactly to to 16 GB.
                                                                                                                                                            2. Check swap configuration
                                                                                                                                                              1. Command: sudo swapon --show --bytes
                                                                                                                                                                1. Output
                                                                                                                                                                  NAME      TYPE        SIZE USED PRIO
                                                                                                                                                                  /swapfile file 17179865088    0   -2
                                                                                                                                                              2. Reboot
                                                                                                                                                                1. Check swap configuration
                                                                                                                                                                  1. Command: sudo swapon --show --bytes
                                                                                                                                                                    1. Output
                                                                                                                                                                      NAME      TYPE        SIZE USED PRIO
                                                                                                                                                                      /swapfile file 17179865088    0   -2
                                                                                                                                                                      
                                                                                                                                                                      1. Comment
                                                                                                                                                                        1. The reboot verified that fstab is properly configured for the swapfile.

                                                                                                                                                                    References