This is part two of the posts I am putting together to help you get started using Open Source on IBM i. You can use the default shell; however, if you want an easier shell to work with, one that comes with history and more customization bash is the way to go. I started out using the default shell and it was very challenging for me. Even the command prompt in Windows has up-arrow history. If I typed a command wrong I had to start all over typing it again. Let’s just say that got old real quick. Enough talking let’s get down to business.
When I first connected to the system this is what it looked like. I received an error about my home directory not existing (I talked about this in my last post but wanted to cover it again). I created the directory and set the permissions using chmod.
data:image/s3,"s3://crabby-images/043c2/043c2fae6291eb18d24b2286f6248cf4516e81bc" alt=""
Step 1: Switching from the Default Shell to Bash
There are 3 different options here: (these are taken from the IBM i BitBucket Repository — this site has a ton of great information)
- Set current user’s shell
- Set another user’s default shell
- Set the default shell for the system
-- set current user's shell CALL QSYS2.SET_PASE_SHELL_INFO('*CURRENT', '/QOpenSys/pkgs/bin/bash');-- set a specific user's shell -- (requires *SECADM special auth plus *USE and *OBJMGT to the user profile) --***Change THATUSER to the username of the user profile that you want to configure*** CALL QSYS2.SET_PASE_SHELL_INFO('THATUSER', '/QOpenSys/pkgs/bin/bash');-- set the default shell which is returned for users that do not have -- (requires *SECADM special auth plus *USE and *OBJMGT to QSYS) CALL QSYS2.SET_PASE_SHELL_INFO('*DEFAULT', '/QOpenSys/pkgs/bin/bash');
For testing and example purposes I ran CALL QSYS2.SET_PASE_SHELL_INFO(‘OPNSRCPGMR’, ‘/QOpenSys/pkgs/bin/bash’); in Run SQL Scripts. The OPNSRCPGMR user is the user I am using for my testing purposes.
Let’s try connecting to the system again.
data:image/s3,"s3://crabby-images/a0258/a0258c1c471019579882d228aa4e7e6b6329b812" alt=""
Looks like bash to me! This gives us history and a better user experience; however, let’s go a step further. Josh Hall was kind enough to share this with me.
NOTE: This next step is optional. If you decide not to move forward and to stick with plain bash check out the part below about adjusting your PATH.
Step 2: A Better Bash Experience
Making these changes gives us an even better bash experience with better history, command line completion, git prompt, git bash completion, etc.
yum install yum-utils yum-config-manager --add-repo http://rpms.sobo.red/ibmi/ yum clean metadata yum install ibmi-dotfiles ibmi-dotfiles
This installs additional utilities for repository management, sets the repo for several packages, and installs the ibmi-dotfiles. You can see in the screen shot below that the available packages now show the updated repository path.
data:image/s3,"s3://crabby-images/4de7a/4de7a0fbb26ab3ac8f9f08639173e6d2087a8c82" alt=""
Let’s try and run the first command.
yum install yum-utils
data:image/s3,"s3://crabby-images/e35b8/e35b8888f08f5040af673ae87c65c4f428d0ed5b" alt=""
The first command I tried to run fails; that’s not good… This is because my PATH is not set to the open source environment. You can create a .profile document in your user’s home folder or you can set the path for this session or just cd to the path. I am going to use cd just to quickly show how to get this working. Ultimately, adjusting your path will save you time in the long run.
cd /qopensys/pkgs/bin yum install yum-utils
data:image/s3,"s3://crabby-images/4441b/4441bea076e41194d1d51a7ce5f6fd11048e7ad5" alt=""
The below screen shot was taken from the IBM i Bitbucket site found here. This explains how to configure your PATH.
data:image/s3,"s3://crabby-images/ccaf8/ccaf8e3051e8d538b1c67756b4d3c97744337bcf" alt=""
Now that we have the first command in our better bash experience executed let’s move on to the rest.
yum-config-manager --add-repo http://rpms.sobo.red/ibmi/ yum clean metadata yum install ibmi-dotfiles ibmi-dotfiles
When we hit the yum install ibmi-dotfile we will be prompted to install them Y/N, type Y and hit enter.
data:image/s3,"s3://crabby-images/26bb2/26bb25a8d08deb0da2d7d43400250a06fdfcf028" alt=""
You will see the Complete! message letting you know that it installed successfully.
data:image/s3,"s3://crabby-images/57265/572657ac4134c1eac64f4637fdd88051c482a09d" alt=""
Now to run our last command.
ibmi-dotfiles
You will be prompted to enter your name and email for use with Git.
data:image/s3,"s3://crabby-images/53bb9/53bb9fec5f09a16c2d576169c2d88c5698a86d5a" alt=""
Step 3: Open a new SSH terminal
Now we will see the changes.
data:image/s3,"s3://crabby-images/5e53a/5e53a4ba01b4447b20078bb140affd6c56e1067e" alt=""