Ceci est une ancienne révision du document !
Table des matières
SO302 - Package and Boot Environment Administration
Solaris 10 pkgXYZ commands
Introduction
Under Solaris 10, package administration was carried out using the following commands:
Command | Description |
---|---|
pkginfo | Displays information about a package or packages |
pkgadd | Installs a package |
pkgchk | Checks package installation accuracy |
pkgrm | Uninstalls a package |
These commands are still available under Solaris 11.
The Solaris 11 Image Packaging System (IPS)
Introduction
Although still present as shown above, use of the Solaris 10 package management commands has been replaced in Solaris 11 by the Solaris Image Packaging System.
Solaris 11 uses the new Image Packaging System technology combined with the Service Management Facility ( SMF ), the Zettabyte File System ( ZFS ) technologies to greatly simplify both package management and patch management.
The IPS pkg command and its subcommands work much like their Linux counterparts yum, apt-get and zypper, relying on a repository which contains available packages.
pkg Subcommands
The pkg subcommands are as follows:
Subcommand | Description |
---|---|
publisher | Lists current and disabled repositories “published” by publishers |
set-publisher | Adds a publisher |
unset-publisher | Removes a publisher |
list | Lists installed packages |
search | Searches for a package in the system's active publishers and returns the first match found |
install | Installs/Updates packages |
uninstall | Uninstalls packages |
refresh | Updates the cached list of available packages |
update | Updates all or certain packages to their latest versions |
info | Displays information about packages |
contents | Displays files installed by a package |
verify | Validates the installation and digital signature packages |
history | Displays the pkg history |
help | Lists the above and advanced subcommands and their switches |
LAB #1 - Using IPS
Basic pkg subcommands
Firstly, check which publishers are installed on the system:
root@solaris:~# pkg publisher PUBLISHER TYPE STATUS P LOCATION solaris origin online F http://pkg.oracle.com/solaris/release/
You can display additional information about a publisher as follows:
root@solaris:~# pkg publisher solaris Publisher: solaris Alias: Origin URI: http://pkg.oracle.com/solaris/release/ SSL Key: None SSL Cert: None Client UUID: ddee2130-0292-11e2-b9e5-80144f013e20 Catalog Updated: October 16, 2012 09:25:04 PM Enabled: Yes
Now add the OpenIndiana publisher:
root@solaris:~# pkg set-publisher -g http://pkg.openindiana.org/sfe sfe root@solaris:~# pkg publisher PUBLISHER TYPE STATUS P LOCATION solaris origin online F http://pkg.oracle.com/solaris/release/ sfe origin online F http://pkg.openindiana.org/sfe/
To understand the use of the -g switch, use the built-in help function:
root@solaris:~# pkg help set-publisher Usage: pkg set-publisher [-Ped] [-k ssl_key] [-c ssl_cert] [-g origin_to_add|--add-origin=origin_to_add ...] [-G origin_to_remove|--remove-origin=origin_to_remove ...] [-m mirror_to_add|--add-mirror=mirror_to_add ...] [-M mirror_to_remove|--remove-mirror=mirror_to_remove ...] [-p repo_uri] [--enable] [--disable] [--no-refresh] [--reset-uuid] [--non-sticky] [--sticky] [--search-after=publisher] [--search-before=publisher] [--search-first] [--approve-ca-cert=path_to_CA] [--revoke-ca-cert=hash_of_CA_to_revoke] [--unset-ca-cert=hash_of_CA_to_unset] [--set-property name_of_property=value] [--add-property-value name_of_property=value_to_add] [--remove-property-value name_of_property=value_to_remove] [--unset-property name_of_property_to_delete] [--proxy proxy to use] [publisher]
Display additional information about the publisher:
root@solaris:~# pkg publisher sfe Publisher: sfe Alias: Origin URI: http://pkg.openindiana.org/sfe/ SSL Key: None SSL Cert: None Client UUID: e873ddf6-3fba-11e2-8b21-880027ed6b01 Catalog Updated: December 5, 2012 08:40:30 PM Enabled: Yes
Now remove the OpenIndiana publisher:
root@solaris:~# pkg unset-publisher sfe root@solaris:~# pkg publisher PUBLISHER TYPE STATUS P LOCATION solaris origin online F http://pkg.oracle.com/solaris/release/
List all available packages on the system:
root@solaris:~# pkg list | more NAME (PUBLISHER) VERSION IFO archiver/gnu-tar 1.26-0.175.1.0.0.24.0 i-- audio/audio-utilities 0.5.11-0.175.1.0.0.24.2 i-- codec/flac 1.2.1-0.175.0.0.0.0.0 i-- codec/libtheora 1.1.1-0.175.1.0.0.15.0 i-- codec/ogg-vorbis 2.30.0-0.175.1.0.0.12.0 i-- codec/speex 1.2-0.175.1.0.0.15.0 i-- communication/im/pidgin 2.10.5-0.175.1.0.0.24.0 i-- compress/bzip2 1.0.6-0.175.1.0.0.24.0 i-- compress/gzip 1.4-0.175.1.0.0.24.0 i-- compress/p7zip 9.20.1-0.175.1.0.0.24.0 i-- compress/unzip 6.0-0.175.1.0.0.24.0 i-- compress/xz 5.0.1-0.175.1.0.0.24.0 i-- compress/zip 3.0-0.175.1.0.0.24.0 i-- consolidation/SunVTS/SunVTS-incorporation 0.5.11-0.175.1.0.0.14.0 i-- consolidation/X/X-incorporation 0.5.11-0.175.1.0.0.24.1317 i-- consolidation/admin/admin-incorporation 0.5.11-0.175.1.0.0.5.0 i-- consolidation/cacao/cacao-incorporation 0.5.11-0.175.1.0.0.11.0 i-- consolidation/cde/cde-incorporation 0.5.11-0.175.0.0.0.0.0 i-- consolidation/cns/cns-incorporation 0.5.11-0.175.1.0.0.23.0 i-- consolidation/dbtg/dbtg-incorporation 0.5.11-0.175.1.0.0.15.0 i-- consolidation/desktop/desktop-incorporation 0.5.11-0.175.1.0.0.24.2 i-- consolidation/desktop/gnome-incorporation 0.5.11-0.175.1.0.0.22.0 i-- consolidation/gfx/gfx-incorporation 0.5.11-0.175.1.0.0.5.0 i-- consolidation/install/install-incorporation 0.5.11-0.175.1.0.0.24.1736 i-- consolidation/ips/ips-incorporation 0.5.11-0.175.1.0.0.24.0 i-- consolidation/java/java-incorporation 0.5.11-0.175.1.0.0.24.0 i-- consolidation/jdmk/jdmk-incorporation 0.5.11-0.173.0.0.0.0.0 i-- consolidation/l10n/l10n-incorporation 0.5.11-0.175.1.0.0.23.1134 i-- consolidation/man/man-incorporation 0.5.11-0.175.1.0.0.21.0 i-- consolidation/nspg/nspg-incorporation 0.5.11-0.175.1.0.0.5.0 i-- consolidation/nvidia/nvidia-incorporation 0.5.11-0.175.1.0.0.22.0 i-- consolidation/osnet/osnet-incorporation 0.5.11-0.175.1.0.0.24.2 i-- consolidation/sfw/sfw-incorporation 0.5.11-0.175.1.0.0.5.0 i-- consolidation/sic_team/sic_team-incorporation 0.5.11-0.175.1.0.0.5.0 i-- consolidation/solaris_re/solaris_re-incorporation 0.5.11-0.175.1.0.0.24.3 i-- consolidation/sunpro/sunpro-incorporation 0.5.11-0.175.1.0.0.19.0 i-- consolidation/ub_javavm/ub_javavm-incorporation 0.5.11-0.175.1.0.0.24.1 i-- consolidation/userland/userland-incorporation 0.5.11-0.175.1.0.0.24.0 i-- consolidation/vpanels/vpanels-incorporation 0.5.11-0.175.1.0.0.17.0 i-r consolidation/xvm/xvm-incorporation 0.5.11-0.175.1.0.0.5.0 i-- crypto/ca-certificates 0.5.11-0.175.1.0.0.24.2 i--
Note the IFO column:
Letter | Description |
---|---|
i | The package is installed |
f | The package is frozen and cannot be updated |
o | The package is obsolete |
To understand the r in the third column of the vpanels-incorporation package, use the info subcommand:
root@solaris:~# pkg info vpanels-incorporation Name: consolidation/vpanels/vpanels-incorporation Summary: State: Installed (Renamed) Renamed to: pkg:/consolidation/userland/userland-incorporation pkg:/consolidation/osnet/osnet-incorporation Publisher: solaris Version: 0.5.11 Build Release: 5.11 Branch: 0.175.1.0.0.17.0 Packaging Date: May 29, 2012 10:02:23 PM Size: 5.46 kB FMRI: pkg://solaris/consolidation/vpanels/vpanels-incorporation@0.5.11,5.11-0.175.1.0.0.17.0:20120529T220223Z
Use the list subcommand to easily identify the package version number of a single package:
root@solaris:~# pkg list vpanels-incorporation NAME (PUBLISHER) VERSION IFO consolidation/vpanels/vpanels-incorporation 0.5.11-0.175.1.0.0.17.0 i-r
To identify the package creation timestamp, use the -v switch of the list subcommand:
root@solaris:~# pkg list -v vpanels-incorporation FMRI IFO pkg://solaris/consolidation/vpanels/vpanels-incorporation@0.5.11,5.11-0.175.1.0.0.17.0:20120529T220223Z i-r
The output of this command shows a line of the following format:
FMRI Scheme://Publisher/Package Name@Version,Build Release-Branch:Package Creation Timestamp IFO
The name FMRI means Fault Managed Resource Identifier. FMRIs are covered in the Service Administration lesson of this course.
Wildcards can be used to list packages available, either installed or not:
root@solaris:~# pkg list -a compress* NAME (PUBLISHER) VERSION IFO compress/bzip2 1.0.6-0.175.1.0.0.24.0 i-- compress/gzip 1.4-0.175.1.0.0.24.0 i-- compress/lcab (sfe) 1.0.12-0.151.1.5 --- compress/lcab/src (sfe) 1.0.12-0.151.1.5 --- compress/lha (sfe) 1.14.9.1-0.151.1.5 --- compress/lha/src (sfe) 1.14.9.1-0.151.1.5 --- compress/p7zip 9.20.1-0.175.1.0.0.24.0 i-- compress/unzip 6.0-0.175.1.0.0.24.0 i-- compress/unzoo (sfe) 4.4-0.151.1.5 --- compress/unzoo/src (sfe) 4.4-0.151.1.5 --- compress/xz 5.0.1-0.175.1.0.0.24.0 i-- compress/zip 3.0-0.175.1.0.0.24.0 i--
To display the number of installed packages, use the following command:
root@solaris:~# pkg list | wc -l 873
To display the number of installed and available packages, use the -a switch:
root@solaris:~# pkg list -a | wc -l 2615
Installing a Package
You are now going to install the ClamAV anti-virus package. This package is available from the OpenIndiana publisher. In order to use that publisher you need to add it once more:
root@solaris:~# pkg set-publisher -g http://pkg.openindiana.org/sfe sfe root@solaris:~# pkg publisher PUBLISHER TYPE STATUS P LOCATION solaris origin online F http://pkg.oracle.com/solaris/release/ sfe origin online F http://pkg.openindiana.org/sfe/
There are two ways to identify the package name before being able to install it, either by using the list subcommand:
root@solaris:~# pkg list -a | grep clamav antivirus/clamav (sfe) 0.97.6-0.151.1.6 --- antivirus/clamav/src (sfe) 0.97.6-0.151.1.6 --- security/clamav (sfe) 0.97.3-0.151.1 --r
or, alternatively by using the search subcommand:
root@solaris:~# pkg search antivirus/clamav INDEX ACTION VALUE PACKAGE require depend pkg:/antivirus/clamav@0.97.5,5.11-0.151.1.5 pkg:/security/clamav@0.97.3-0.151.1 pkg.fmri set sfe/antivirus/clamav pkg:/antivirus/clamav@0.97.5-0.151.1.5
Installing ClamAV is now very simple:
root@solaris:~# pkg install antivirus/clamav Packages to install: 3 Create boot environment: No Create backup boot environment: No DOWNLOAD PKGS FILES XFER (MB) SPEED Completed 3/3 55/55 1.7/1.7 458k/s PHASE ITEMS Installing new actions 110/110 Updating package state database Done Updating image state Done Creating fast lookup database Done
To check whether the package is now installed, use the list subcommand:
root@solaris:~# pkg list clamav NAME (PUBLISHER) VERSION IFO antivirus/clamav (sfe) 0.97.6-0.151.1.6 i--
or the verify subcommand:
root@solaris:~# pkg verify -v clamav PACKAGE STATUS pkg://sfe/antivirus/clamav OK
Remember that for more information about the installed package, you can use the info subcommand:
root@solaris:~# pkg info clamav Name: antivirus/clamav Summary: Unix anti-virus scanner Category: Applications/System Utilities State: Installed Publisher: sfe Version: 0.97.6 Build Release: 5.11 Branch: 0.151.1.6 Packaging Date: October 1, 2012 08:13:32 PM Size: 3.95 MB FMRI: pkg://sfe/antivirus/clamav@0.97.6,5.11-0.151.1.6:20121001T201332Z
By using the which command, you will notice that there is no clamav program in /bin or /usr/bin:
root@solaris:~# which clamav no clamav in /usr/bin /usr/sbin
So, either the program is not called clamav or it is elsewhere in the filesystem. In order to see which files the package installed, use the contents subcommand:
root@solaris:~# pkg contents antivirus/clamav PATH etc etc/clamav-milter.conf etc/clamd.conf etc/freshclam.conf usr usr/bin usr/bin/clamav-config usr/bin/clambc usr/bin/clamconf usr/bin/clamdscan usr/bin/clamdtop usr/bin/clamscan usr/bin/freshclam usr/bin/sigtool usr/include usr/include/clamav.h usr/lib usr/lib/libclamav.so usr/lib/libclamav.so.6 usr/lib/libclamav.so.6.1.15 usr/lib/libclamunrar.so usr/lib/libclamunrar.so.6 usr/lib/libclamunrar.so.6.1.15 usr/lib/libclamunrar_iface.so usr/lib/libclamunrar_iface.so.6 usr/lib/libclamunrar_iface.so.6.1.15 usr/lib/pkgconfig usr/lib/pkgconfig/libclamav.pc usr/sbin usr/sbin/clamav-milter usr/sbin/clamd usr/share usr/share/doc usr/share/doc/clamav usr/share/doc/clamav/COPYING usr/share/doc/clamav/COPYING.LGPL usr/share/doc/clamav/COPYING.bzip2 usr/share/doc/clamav/COPYING.file usr/share/doc/clamav/COPYING.getopt usr/share/doc/clamav/COPYING.llvm usr/share/doc/clamav/COPYING.lzma usr/share/doc/clamav/COPYING.regex usr/share/doc/clamav/COPYING.sha256 usr/share/doc/clamav/COPYING.unrar usr/share/doc/clamav/COPYING.zlib usr/share/doc/clamav/ChangeLog usr/share/doc/clamav/FAQ usr/share/doc/clamav/README usr/share/doc/clamav/clamav-mirror-howto.pdf usr/share/doc/clamav/clamdoc.pdf usr/share/doc/clamav/phishsigs_howto.pdf usr/share/doc/clamav/signatures.pdf usr/share/man usr/share/man/man1 usr/share/man/man1/clambc.1 usr/share/man/man1/clamconf.1 usr/share/man/man1/clamdscan.1 usr/share/man/man1/clamdtop.1 usr/share/man/man1/clamscan.1 usr/share/man/man1/freshclam.1 usr/share/man/man1/sigtool.1 usr/share/man/man5 usr/share/man/man5/clamav-milter.conf.5 usr/share/man/man5/clamd.conf.5 usr/share/man/man5/freshclam.conf.5 usr/share/man/man8 usr/share/man/man8/clamav-milter.8 usr/share/man/man8/clamd.8 var var/clamav
As you can see, the package installed the following programs:
usr/bin/clamav-config usr/bin/clambc usr/bin/clamconf usr/bin/clamdscan usr/bin/clamdtop usr/bin/clamscan usr/bin/freshclam usr/bin/sigtool usr/sbin/clamav-milter usr/sbin/clamd
Uninstalling a Package
Uninstalling the package is now as simple as installing it:
root@solaris:~# pkg uninstall clamav Packages to remove: 3 Create boot environment: No Create backup boot environment: No PHASE ITEMS Removing old actions 101/101 Updating package state database Done Updating package cache 3/3 Updating image state Done Creating fast lookup database Done
The uninstall subcommand removes all files installed by a package, except those that are dependencies of another installed package.
Searching for a Package containing a specific Program
You can also search for a package that contains a specific program:
root@solaris:~# pkg search /usr/bin/clamdscan INDEX ACTION VALUE PACKAGE path file usr/bin/clamdscan pkg:/antivirus/clamav@0.97.5-0.151.1.5 path file usr/bin/clamdscan pkg:/security/clamav@0.97.3-0.151.1
Updating Packages
The pkg command can also be used to update installed packages:
root@solaris:~# pkg update No updates available for this image.
If you wish to update a specific package to the latest available version, use the following syntax : pkg update package@latest.
Solaris 11 Boot Environments
Solaris Boot Environments ( BE ) are an interaction between the IPS et ZFS technologies. Boot Environments offer an administrator a very efficient rollback facility. A Boot Environment is a ZFS file system that is designated for booting, in other words a bootable instance of the Operating System plus any other software added specifically to that image. It is possible to have as many Boot Environments as needed.
Imagine that you decide to update the Solaris kernel using IPS. In order to make sure that you can rollback to the previous version in the case of any problems, you would create a Boot Environment before updating. After updating the kernel you would have two Boot Environments, one before the update and one after the update.
Boot Environments are managed with the beadm command. As with the IPS pkg command, the Boot Environments' beadm command uses a set of subcommands.
beadm Subcommands
The beadm subcommands are as follows:
Subcommand | Description |
---|---|
list | Lists all available Boot Environments |
list BEname | Lists the Boot Environment called BEname |
create BEname | Creates a clone, called BEname of the current active Boot Environment. Options allow for creating from an inactive or snapshot Boot Environment |
create BEname@SNAPname | Creates a snapshot called SNAPname of the Boot Environment BEname |
activate BEname | Configures the Boot Environment BEname to be used at the next reboot |
destroy BEname | Erases the Boot Environment BEname and all associated snapshots |
mount BEname | Mounts the Boot Environment BEname on mount point for inspection |
unmount BEname | Unmounts the Boot Environment BEname |
rename BEname newBEname | Renames the Boot Environment BEname to newBEname |
LAB #2 - Managing Boot Environments
Using the beadm Command
First, list the current available Boot Environments:
root@solaris:~# beadm list BE Active Mountpoint Space Policy Created -- ------ ---------- ----- ------ ------- solaris NR / 6.36G static 2012-11-20 19:08 solaris-backup-1 - - 159.0K static 2012-11-20 22:20
This output shows the solaris Boot Environment that was automatically created during the installation process together with the solaris-backup-1 Boot Environment that was automatically created by the system after the installation process.
You will notice that the Active column shows two letters:
Letter | Description |
---|---|
N | The Boot Environment is active Now |
R | The Boot Environment will be active upon the next Reboot |
Now create a new Boot Environment called MyBE:
root@solaris:~# beadm create MyBE root@solaris:~# beadm activate MyBE root@solaris:~# beadm list BE Active Mountpoint Space Policy Created -- ------ ---------- ----- ------ ------- MyBE - - 199.0K static 2012-12-07 10:43 solaris NR / 6.36G static 2012-11-20 19:08 solaris-backup-1 - - 159.0K static 2012-11-20 22:20
Note that the new Boot Environment MyBE, a clone of solaris, has been created but is not active. Clones are bootable images.
Activate the Boot Environment MyBE so it will used upon the next reboot:
root@solaris:~# beadm list BE Active Mountpoint Space Policy Created -- ------ ---------- ----- ------ ------- MyBE R - 6.36G static 2012-12-07 10:43 solaris N / 45.0K static 2012-11-20 19:08 solaris-backup-1 - - 159.0K static 2012-11-20 22:20
Note here that the Boot Environment MyBE is now flagged to be used upon the next reboot.
At this point take a snapshot of the solaris-backup-1 Boot Environment:
root@solaris:~# beadm create solaris-backup-1@SNAP-solaris-backup-1 root@solaris:/# beadm list -a solaris-backup-1 BE/Dataset/Snapshot Active Mountpoint Space Policy Created ------------------- ------ ---------- ----- ------ ------- solaris-backup-1 rpool/ROOT/solaris-backup-1 - - 113.0K static 2012-11-20 22:20 rpool/ROOT/solaris-backup-1/var - - 46.0K static 2012-11-20 22:20 rpool/ROOT/solaris-backup-1/var@SNAP-solaris-backup-1 - - 0 static 2012-12-07 10:48 rpool/ROOT/solaris-backup-1@SNAP-solaris-backup-1 - - 0 static 2012-12-07 10:48
A snapshot is a read-only, non-bootable image of a Boot Environment at a given point in time.
As you can see the snapshot is created in the ROOT dataset. A dataset is a generic term for a ZFS filesystem, zone, snapshot or volume.
I will be telling you more about the ZFS filesystem in the Storage Administration lesson of this course.
If you take a look at the current ZFS configuration you will see the following:
root@solaris:/# zfs list NAME USED AVAIL REFER MOUNTPOINT rpool 6.99G 12.3G 4.58M /rpool rpool/ROOT 4.84G 12.3G 31K legacy rpool/ROOT/MyBE 4.84G 12.3G 3.90G / rpool/ROOT/MyBE/var 863M 12.3G 205M /var rpool/ROOT/solaris 83K 12.3G 3.90G / rpool/ROOT/solaris-backup-1 113K 12.3G 1.98G / rpool/ROOT/solaris-backup-1/var 46K 12.3G 758M /var rpool/ROOT/solaris/var 83K 12.3G 205M /var rpool/VARSHARE 57K 12.3G 57K /var/share rpool/dump 1.03G 12.4G 1.00G - rpool/export 77.4M 12.3G 32K /export rpool/export/home 77.4M 12.3G 32K /export/home rpool/export/home/trainee 77.4M 12.3G 77.4M /export/home/trainee rpool/swap 1.03G 12.4G 1.00G -
In the above output you can see that the ROOT dataset contains each Boot Environment's Critical Dataset. Any other Shared Datasets, such as /export which contain mount points common to both the active and inactive boot environments are located outside the root dataset area of each boot environment.
Use the destroy subcommand to erase the MyBE Boot Environment:
root@solaris:/# beadm destroy MyBE Are you sure you want to destroy MyBE? This action cannot be undone(y/[n]): y The BE that was just destroyed was the 'active on boot' BE. solaris is now the 'active on boot' BE. Use 'beadm activate' to change it.
Note that the solaris Boot Environment has now been activated.
Check the zfs configuration:
root@solaris:/# zfs list NAME USED AVAIL REFER MOUNTPOINT rpool 6.99G 12.3G 4.58M /rpool rpool/ROOT 4.84G 12.3G 31K legacy rpool/ROOT/solaris 4.84G 12.3G 3.90G / rpool/ROOT/solaris-backup-1 113K 12.3G 1.98G / rpool/ROOT/solaris-backup-1/var 46K 12.3G 758M /var rpool/ROOT/solaris/var 863M 12.3G 205M /var rpool/VARSHARE 57.5K 12.3G 57.5K /var/share rpool/dump 1.03G 12.4G 1.00G - rpool/export 77.6M 12.3G 32K /export rpool/export/home 77.5M 12.3G 32K /export/home rpool/export/home/trainee 77.5M 12.3G 77.5M /export/home/trainee rpool/swap 1.03G 12.4G 1.00G -
If you want to look at the contents of a specific Boot Environment, all you have to do is mount it:
root@solaris:/# mkdir /tmp/be root@solaris:/# beadm mount solaris-backup-1 /tmp/be root@solaris:/# ls -l /tmp/be total 104 lrwxrwxrwx 1 root root 9 Nov 20 19:19 bin -> ./usr/bin drwxr-xr-x 6 root sys 9 Nov 20 19:19 boot drwxr-xr-x 2 root root 4 Nov 20 19:09 cdrom drwxr-xr-x 29 root sys 239 Nov 20 19:25 dev drwxr-xr-x 5 root sys 5 Nov 20 19:25 devices drwxr-xr-x 74 root sys 165 Nov 20 21:40 etc drwxr-xr-x 2 root root 2 Nov 20 19:27 export dr-xr-xr-x 2 root root 2 Sep 19 22:09 home drwxr-xr-x 19 root sys 19 Nov 20 19:09 kernel drwxr-xr-x 13 root bin 301 Nov 20 19:09 lib drwxr-xr-x 2 root root 4 Nov 20 19:27 media drwxr-xr-x 2 root sys 2 Nov 20 19:19 mnt dr-xr-xr-x 2 root root 2 Nov 20 19:53 net dr-xr-xr-x 2 root root 2 Nov 20 19:53 nfs4 drwxr-xr-x 2 root sys 2 Sep 19 22:09 opt drwxr-xr-x 5 root sys 5 Sep 19 22:09 platform dr-xr-xr-x 2 root root 2 Sep 19 22:09 proc drwx------ 2 root root 4 Nov 20 19:19 root drwxr-xr-x 2 root root 2 Nov 20 19:08 rpool lrwxrwxrwx 1 root root 10 Nov 20 19:19 sbin -> ./usr/sbin drwxr-xr-x 5 root root 5 Sep 19 22:09 system drwxrwxrwt 2 root sys 2 Nov 20 19:25 tmp drwxr-xr-x 30 root sys 42 Nov 20 19:18 usr drwxr-xr-x 34 root sys 41 Nov 20 19:19 var
Finally, to update the Operating System Kernel, you can use the following command : pkg update-image. This command first makes a clone of the current Boot Environment, proceeds with downloading and installing all required packages into the new clone and finally activates the clone for startup on the next reboot.
References
SO301 - System Installation
Introduction
Solaris 11 was introduced in november 2011 by Oracle who purchased Sun Microsystems in early 2010. Solaris 11 is greatly inspired by Sun's Solaris 10 OS, introduced in 2005 combined with work from the OpenSolaris Community.
Solaris 10 was a major development in Operating Systems and introduced a number of innovative capabilities including:
- Fault and Service Management,
- Multiprocessor/Multicore performance scalability,
- The ZFS filesystem,
- Enhanced security with RBAC ( Role Based Access Control ),
- Virtualization with zones ( also called containers ),
- Hypervisor-based virtualisation for SPARC processors.
Solaris 11 introduces yet more capabilities as well as addressing those areas where Solaris 10 was weak ( such as package management ) compared to OSs such as Linux:
- The Image Packaging System ( IPS ),
- Simpler Automated Installation with AI, replacing jumpstart,
- Network virtualisation,
- Built-in CIFS support,
- Security enhancements,
- New ZFS features,
- CUPS
- Distribution Constructor,
- Boot environments,
- New container features,
- NIC auto-detection,
- Enhanced Multicore processor support.
Installation
Solaris 11 can be installed from one of three ISO images :
Method | Description |
---|---|
Text Install | CD sized ISO which can be used on both x86 and SPARC platforms to install a text only operating system. |
Automated Installer | Same as above but also supports hands-free network-based minimal installations. |
Live Media | DVD sized ISO which boots into a live x86 version of Solaris 11 containing the installation program. |
This training module concentrates on the Text Install and Live Media methods of installation.
The minimum hardware specifications for Solaris 11 are as follows :
Hardware | SPARC | x86 (64-bit ONLY) |
---|---|---|
Processor Achitecture | Sun 4v ( T Series ) , SPARC 64 | Intel Xeon, i3, i5, i7, AMD Opteron |
Minimum Memory | 1GB | 1GB |
Recommended Memory | 1GB | 1GB |
Minimum Disk Space | Text Install: 2.9GB, Automated Installer: 2.5GB, Live Media: 5GB | Text Install: 2.9GB, Automated Installer: 2.5GB, Live Media: 5GB |
Recommended Disk Space | Text Install: 4.9GB, Automated Installer: 13GB, Live Media: 7GB | Text Install: 4,9GB, Automated Installer: 13GB, Live Media: 7GB |
Oracle's Hardware Compatibility List is available at their HCL web site: http://www.oracle.com/webfolder/technetwork/hcl/index.html.
Preparing for Installation
Dual Boot Environments
If you intend to install Solaris 11 alongside Linux:
- Deactivate the Linux swap partition under Linux before proceeding further. This is necessary because the swap partition is seen by Solaris 11 as Linux Swap / Solaris and therefore Solaris 11 will try to use it as a native Solaris partition,
- Note that you must use the Solaris 11 version of the bootloader grub. This is because the Solaris 11 grub has been enhanced to be able to boot both Solaris and Linux whereas the Linux version of grub cannot boot Solaris. You must copy the Linux boot stanza from the Linux grub configuration before installing Solaris so that you can paste it into the Solaris grub configuration,
- If you need to free up disk space on a Linux installation in order to install Solaris 11, you should use the Live Media installation process since it contains the gparted program that you will need to use prior to installing Solaris 11.
If you intend to install Solaris 11 alongside Windows™:
- You should use the native Windows™ disk management tools to free up space.
Virtualisation
Solaris 11 can be installed as a virtual appliance on many hypervisor applications :
- Oracle VirtualBox,
- Oracle VM for x86,
- Oracle VM Server for SPARC,
- VMware vSphere 5.1,
- Xen,
- Citrix XenServer.
During this course you will be using the Oracle VirtualBox application to install and use Solaris 11.
LAB #1 - Installing via Text Install
Create a new virtual machine in VirtualBox with a 20GB vmdk hard disk and 2048MB of RAM.
Start the new machine and tell it to boot the Text Install ISO:
The process then starts to probe for devices:
The system now prompts you to choose a keyboard layout:
Followed by the choice of the installation language:
The system is now ready to be installed. Choose the default value of 1 and hit ↵ Enter:
A screen showing both the installation log location and some instructions appears:
Move to the following screen using the F2 key. If the function key does not work or is absent, hit Esc then Esc 2 at the same time. This screen asks you to choose either Local Disks or iSCSI LUN discovery. For the purpose of this installation, you should choose Local Disks:
Move to the next screen using the F2 key or the Esc 2 keys as shown at the bottom of the current screen:
The system should now have discovered the local disk to install to. Since in the case of this example, we are installing to a new media, no GPT labeled disk has been found. The installation program suggests a partition table. Note the name of the device is of the following format c?t?d?:
Letter | Description | Starting Value |
---|---|---|
c | Disk controller device number | 0 |
t | Controller's target number | 0 |
d | Disk number on the controller | 0 |
Make sure the disk is highlighted and then hit ↵ Enter:
At this stage you can choose to either install to the entire disk ( the default choice ) or install to a partition in the case of a multiple boot environment. Highlight the Use the entire disk option and hit the F2 key or the the Esc 2 keys:
You now need to specify a name for the system. Use the same one as in the example - fenestros.solaris.loc:
Highlight the Automatically option in order to automatically configure the network connection via DHCP and hit the F2 key or the the Esc 2 keys:
Select the region that contains your time zone and hit the F2 key or the the Esc 2 keys:
Select the location that contains your time zone and hit the F2 key or the the Esc 2 keys:
Select your time zone and hit the F2 key or the the Esc 2 keys:
Check the date and time and correct if necessary then hit the F2 key or the the Esc 2 keys:
You now need to specify the root ( Administrator ) password and the name and password of the first user on the system. Several points need to be considered here :
- The default password-hashing program in Solaris 11 is SHA-256. This means that the passwords are no longer limited to 8 characters as in the case of Solaris 10,
- The default password security policy requires that passwords contain at least one digit and one special character,
- Under Solaris 11, the root user is a role indicating that you cannot log in directly with the root account,
- The first user created on the system is assigned the root role so that he/she can become root using the su command.
For the purposes of this training course, specify fenestr0$ as the password for root and trainee/fenestr0$ as the username and password of the user to be created.
When installing a machine for production purposes, do not use the same password for the root and user account!
When you have finished, hit the F2 key or the the Esc 2 keys:
At this stage you should enter the email address and password of your Oracle Support Account.
Oracle's licensing policy for Solaris 11 does not permit you to put a Solaris 11 system into production without an Oracle Support Account.
Since the licensing policy does allow you to evaluate Solaris 11 for an indefinite period, enter your email address but leave the password field empty. When finished hit the F2 key or the the Esc 2 keys:
If your network uses a proxy, enter the details here. If not choose the No proxy option and hit the F2 key or the the Esc 2 keys:
Review the Installation Summary and modify it if necessary. If not, hit the F2 key or the the Esc 2 keys:
The system will now be installed:
At the end on the installation, the screen shows you where you will find the installation log after rebooting. Hit the F8 key to reboot:
Your newly installed Solaris 11 system will reboot:
Once booted, log into the system from the command line using the trainee/fenestr0$ account. In order to install the gnome desktop environement, use the following command :
trainee@solaris:~$ sudo pkg install slim_install Password: fenestr0$
The password will not be shown. It is so in the example above so that you do not forget what it is!
Once all the packages are installed, use the following command to start the graphical log in service at boot:
trainee@solaris:~$ sudo svcadm enable gdm
Re-boot the machine and log in graphically :
Once logged back in, you need to install the VirtualBox Guest Additions. To do so click on the VirtualBox Devices menu. Select the Install Guest Additions menu item. VirtualBox will mount the VirtualBox Guest Additions ISO and an icon will appear on your desktop:
Double click on the icon to open the window containing it's contents:
Highlight the VBoxSolarisAdditions.pkg package and click on the Open Autorun Prompt button:
In the pop-up box, click on the Run button:
In the terminal that pops up asking for a password, type fenestr0$:
Wait until the installation has completed and then hit ↵ Enter to close the terminal:
Eject the ISO image and reboot the system.
LAB #2 - Live Install in VirtualBox
Create a new virtual machine in VirtualBox with a 20GB vmdk hard disk and 2048MB of RAM.
Start the new machine and tell it to boot the Live Media ISO:
From the grub boot menu, choose the Oracle Solaris 11.1 item and hit ↵ Enter:
The Live system will boot:
The system now prompts you to choose a keyboard layout:
Followed by the choice of the installation language:
When the system asks you to log in at the command line, do NOTHING. Wait until the graphical interface launches.
Once the graphical interface has launched, double click on the Device Driver Utility icon and click on the OK button to run the program as root. When prompted enter solaris as the root password:
After a little while, the Device Driver Utility will show you any eventual driver problems:
Close the Device Driver Utility window and double-click on the GParted Partition Editor icon. Using this application you can make space on a disk that already contains a Linux system in order to install Solaris 11:
Close the GParted window and double-click on the Install Oracle Solaris icon:
Using what you have learnt in the Text Install section of this lesson, install Solaris 11 using the Live Media. Once installed, log in, open a terminal and try to switch to the root role. Note that the root password has expired. Set the new root password to wind0w$. Finally install the VirtualBox Additions.
<html> <div align=“center”> Copyright © 2019 Hugh Norris. </html>