Building SaltStack - linux-on-ibm-z/docs GitHub Wiki
Building SaltStack
Below versions of SaltStack(Salt) are available in respective distributions at the time of creation of these build instructions:
- SLES 15 SP5 has
3006.0
- Ubuntu 22.04 has
3004.1
- RHEL (9.0, 9.2, 9.3) have
3005.4
The instructions provided below specify the steps to build SaltStack(Salt) v3006.5 on Linux on IBM Z for the following distributions:
- RHEL (7.8, 7.9, 8.6, 8.8, 8.9, 9.0, 9.2, 9.3)
- SLES (12 SP5, 15 SP5)
- Ubuntu (20.04, 22.04, 23.10)
General notes:
- When following the steps below please use a standard permission user unless otherwise specified.
- A directory
/<source_root>/
will be referred to in these instructions, this is a temporary writable directory anywhere you'd like to place it.
Step 1: Build using script
If you want to build Salt using manual steps, go to STEP 2.
Use the following commands to build Salt using the build script. Please make sure you have wget installed.
wget -q https://raw.githubusercontent.com/linux-on-ibm-z/scripts/master/SaltStack/3006.5/build_salt.sh
# Build Salt
bash build_salt.sh [Provide -t for executing build with tests]
If the build completes successfully, go to STEP 5 to configure salt. In case of error, check logs
for more details or go to STEP 2 to follow manual build steps.
Step 2: Install the dependencies
export SOURCE_ROOT=/<source_root>/
-
RHEL (7.8, 7.9)
sudo yum install -y procps-ng cyrus-sasl-devel gcc gcc-c++ git libffi-devel libtool libxml2-devel libxslt-devel make man swig tar wget bzip2-devel gdbm-devel libdb-devel libuuid-devel ncurses-devel readline-devel sqlite-devel tar tk-devel xz xz-devel zlib-devel zeromq-devel
- Install Openssl
cd $SOURCE_ROOT wget https://www.openssl.org/source/openssl-1.1.1q.tar.gz --no-check-certificate tar -xzf openssl-1.1.1q.tar.gz cd openssl-1.1.1q ./config --prefix=/usr/local --openssldir=/usr/local make sudo make install sudo ldconfig /usr/local/lib64 export PATH=/usr/local/bin:$PATH export LDFLAGS="-L/usr/local/lib/ -L/usr/local/lib64/" export LD_LIBRARY_PATH="/usr/local/lib/:/usr/local/lib64/" export PKG_CONFIG_PATH=/usr/local/lib64/pkgconfig export CPPFLAGS="-I/usr/local/include/ -I/usr/local/include/openssl"
- Install Openssl
-
RHEL (8.6, 8.8, 8.9)
sudo yum install -y procps-ng cyrus-sasl-devel gcc gcc-c++ git libffi-devel libtool libxml2-devel libxslt-devel make man swig tar wget cmake bzip2-devel gdbm-devel libdb-devel libnsl2-devel libuuid-devel ncurses-devel openssl openssl-devel readline-devel sqlite-devel tk-devel xz xz-devel zlib-devel glibc-langpack-en diffutils zeromq-devel
-
RHEL (9.0, 9.2, 9.3)
sudo yum install -y procps-ng cyrus-sasl-devel gcc gcc-c++ git libffi-devel libtool libxml2-devel libxslt-devel make man openssl-devel swig tar wget cmake python3-devel python3-pip zeromq-devel
-
SLES 12 SP5
sudo zypper install -y curl cyrus-sasl-devel gawk gcc gcc-c++ git libopenssl-devel libxml2-devel libxslt-devel make man tar wget cmake libnghttp2-devel gdbm-devel libbz2-devel libdb-4_8-devel libffi48-devel libuuid-devel ncurses-devel readline-devel sqlite3-devel tk-devel xz-devel zlib-devel gzip
-
SLES 15 SP5
sudo zypper install -y curl cyrus-sasl-devel gawk gcc gcc-c++ git libopenssl-devel libxml2-devel libxslt-devel make man tar wget cmake libnghttp2-devel gdbm-devel libbz2-devel libdb-4_8-devel libffi-devel libuuid-devel ncurses-devel readline-devel sqlite3-devel tk-devel xz-devel zlib-devel gzip
-
Ubuntu 20.04
sudo apt-get update sudo apt-get install -y wget g++ gcc git libffi-dev libsasl2-dev libssl-dev libxml2-dev libxslt1-dev libzmq3-dev make man python3-dev python3-pip tar libz-dev pkg-config apt-utils curl cmake
-
Ubuntu (22.04, 23.10)
sudo apt-get update sudo apt-get install -y wget g++ gcc git libffi-dev libsasl2-dev libssl-dev libxml2-dev libxslt1-dev libzmq3-dev make man tar wget libz-dev pkg-config apt-utils curl cmake libbz2-dev libdb-dev libgdbm-dev liblzma-dev libncurses-dev libreadline-dev libsqlite3-dev tk-dev uuid-dev xz-utils zlib1g-dev
2.1) Install Python and required dependencies
-
Install
Python 3.10.2
(RHEL (7.x, 8.x), SLES and Ubuntu 22.04, 23.10)cd $SOURCE_ROOT wget https://www.python.org/ftp/python/3.10.2/Python-3.10.2.tgz tar -xzf Python-3.10.2.tgz cd Python-3.10.2 ./configure --prefix=/usr/local --exec-prefix=/usr/local make sudo make install export PATH=/usr/local/bin/python3.10:$PATH python3 -V
-
Install M2Crypto (RHEL only)
pip3 install M2Crypto
-
Install Rust
curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs | sh -s -- -y source $HOME/.cargo/env rustup default 1.56.0
-
Install Libgit2
cd $SOURCE_ROOT wget https://github.com/libgit2/libgit2/archive/refs/tags/v1.7.0.tar.gz tar xzf v1.7.0.tar.gz cd libgit2-1.7.0/ cmake . make sudo make install
-
Install Python packages-
pip3 install pyzmq 'PyYAML<5.1' pycrypto msgpack-python jinja2 psutil futures==2.2.0 tornado python-dateutil genshi #for Ubuntu only pip3 install pyzmq 'PyYAML<5.1' pycrypto msgpack-python jinja2 psutil futures tornado python-dateutil genshi #for RHEL and SLES only
Step 3: Build and install
3.1) Clone the repository and install SaltStack
cd $SOURCE_ROOT
git clone https://github.com/saltstack/salt.git
cd salt
git checkout v3006.5
pip3 install -e .
Step 4: Test SaltStack (Optional)
cd $SOURCE_ROOT/salt
pip3 install nox
CFLAGS="-std=c99" python3 -m nox -e "test-3(coverage=False)" -- tests/pytests/unit/cli/test_batch.py (only for RHEL 7.x and sles 12.5)
python3 -m nox -e "test-3(coverage=False)" -- tests/pytests/unit/cli/test_batch.py (All distros except RHEL 7.x and sles 12.5)
Step 5: Configure SaltStack to run self-contained version
- Edit
$SOURCE_ROOT/salt/master
and$SOURCE_ROOT/salt/minion
:
currentuser="$(whoami)"
sed -i "s/#user: root/user: $currentuser/" conf/master
sed -i 's,#root_dir: /,'"root_dir: $SOURCE_ROOT"',' conf/master
sed -i 's/#publish_port: 4505/publish_port: 4505/' conf/master
sed -i 's/#ret_port: 4506/ret_port: 4506/' conf/master
sed -i 's/#master: salt/master: localhost/' conf/minion
sed -i "s/#user: root/user: $currentuser/" conf/minion
sed -i 's,#root_dir: /,'"root_dir: $SOURCE_ROOT"',' conf/minion
sed -i 's/#master_port: 4506/master_port: 4506/' conf/minion
sed -i 's/#id:/id: saltdev/' conf/minion
_**Note**: If the ret_port value in the master config file is changed, set the same value to master_port value in the minion config file_
-
Now you can start your Salt master and minion, specifying the config dir.:
salt-master --config-dir=$SOURCE_ROOT/salt/conf --log-level=debug --daemon salt-minion --config-dir=$SOURCE_ROOT/salt/conf --log-level=debug --daemon
Note: If above command throws error
salt-master: command not found
then set PATH asexport PATH=$SOURCE_ROOT/.local/bin:$PATH
-
Now you should be able to accept the minion key:
salt-key -c $SOURCE_ROOT/salt/conf -Ay
-
Check that your master/minion are communicating:
salt -c $SOURCE_ROOT/salt/conf \* test.version