WilliamLam.com

  • About
    • About
    • Privacy
  • VMware Cloud Foundation
    • VMware Cloud Foundation 9
  • VKS
  • Homelab
    • Hardware Options
    • Hardware Reviews
    • Lab Deployment Scripts
    • Nested Virtualization
    • Homelab Podcasts
  • VMware Nostalgia
  • Apple
You are here: Home / Uncategorized / Automating ESXi 4.1 Kickstart Tips & Tricks

Automating ESXi 4.1 Kickstart Tips & Tricks

09.11.2010 by William Lam // 25 Comments

While testing the new kickstart functionality in ESXi 4.1, I ran into a few issues trying to convert a classic ESX 4.x deployment to ESXi 4.1. I thought I share some of the tips and tricks I have learned, so others will not encounter the same issues.

Before diving in and creating an ESXi 4.1 kickstart configuration, make sure you spend some time going over the documentation provided by VMware, specifically the ESXi Installable and vCenter Server Setup Guide.

UPDATE: For ESXi 5, Check out ESXi5 Kickstart Tips & Tricks

Tip #1

If you are going to specify a ks.cfg (kickstart configuration file) in your pxelinux file, make sure that the kickstart entry is appended after the *vmkboot.gz* but before *vmkernel.gz* entry as highlighted in green in the screenshot. If you place it anywhere else in the boot line option, you will receive an error that is not easy to diagnose. Also you want to make sure you add triple dashes (---) after the kickstart line following the required syntax for the boot options as highlighted in orange in the screenshot.

Tip #2

While developing and testing your ks.cfg, you may want to use the new dryrun parameter which parses your kickstart configuration file looking for syntax and formatting errors. In dryrun mode, no installation will be performed but you will be provided with a log of whether your ks.cfg had any errors, warnings or was successful in being validated.

The following screenshot shows a warning where I purposely left out --hostname entry which is generally recommended within the "network" portion of the ks.cfg:

If there are other errors or warnings, they will be displayed within this screen and you can login to the host to view the log for more details (esxi_install.log):

To login to the host, you will press "enter" and you will be prompted for login (press Alt+F1 to go to login screen). The username by default will be "root" and the password is blank, just press enter for the password:

Once logged in, you will want to take a look at the esxi_install.log for more details on how your ks.cfg is being processed and if there are any errors or warnings discovered by the parser:

Tip #3

If you want to enable both local and remote (SSH access) Tech Support Mode on your ESXi host, you now have the ability to do this via host services. You can use the vim-cmd (vimsh) utility to enable these services and both local and remote TSM is disabled by default.

Note: If you want to enable either local and/or remote TSM, you need to make sure you enable and start the service for you to actually be able to SSH into your ESXi host.

Tip #4

With classic ESX, if you needed to transfer additional packages or files to your host, you could easily mount an NFS volume, with ESXi, an NFS client is not available. If need to transfer files for configuration purposes, you can utilize the wget utility.

The syntax for wget is the following:

wget http://webserver/file -O /tmp/file

Tip #5

I have been told by support that you could not configure syslog for your ESXi host without relying on external tools such as vCLI, PowerCLI or vSphere Client. I have found that you actually can configure syslog configurations, though you have to dig a little bit into vim-cmd (vimsh) as it is not available using any of the local esxcfg-* commands. There only three syslog options as provided via vSphere Client in the Advanced Host Configurations: Syslog.Remote.Hostname, Syslog.Remote.Port and Syslog.Local.DatastorePath

Here is the syntax for the syslog options:

vim-cmd hostsvc/advopt/update Syslog.Remote.Hostname string syslog.primp-industries.com
vim-cmd hostsvc/advopt/update Syslog.Remote.Port int 514
vim-cmd hostsvc/advopt/update Syslog.Local.DatastorePath string "[datastoreName] /logfiles/hostName.log"

Note: Currently you can only configure one syslog server for your ESXi host to forward logs to.

Tip #6

Another new new kickstart parameter introduced with ESXi 4.1 is --level that is used in conjunction with %firstboot stanza. This parameter specifies the specific order in which the kickstart firstboot configurations should run with respect to the other startup scripts when your ESXi host first boots. By default, if you leave this out, VMware will automatically create a script called firstboot_001 and number it 999 which will be the very last script to execute. It is a good idea to move any post configurations to the very end, since most of post configuration may rely on specific VMware CLIs and services which must be started up before executing. You of course can change level, but be careful about moving it too early in the boot process.

Here is an example of changing the level to 998:

Once the host has booted up, you can login to see the script that was created from your %firstboot stanza under /etc/vmware/init/init.d

Note: As you can see, the firstboot script has now changed to 998. You will also notice two other scripts set at level 999 that handles updating the password if you decide to set a root password from the default blank, which you should. These custom scripts are generated after the initial build and upon the next reboot, these will be automatically removed.

Tip #7

You may have noticed in Tip #6, we changed the --level to 998, by default all three of these init scripts are set to boot order 999. This was actually done on purpose, the reason being as described earlier, the root password is blank by default. One issue that I found while testing is the inability to enable "Management Traffic" for a VMkernel interface. You can easily enable vMotion and FT Traffic for a VMkernel interface using vim-cmd (vimsh), but you can not for Management Traffic. One way I solved this problem is creating a python script which connects to the local ESXi MOB and enables Management Traffic on a particular VMkernel interface. I have shared this specific script on the on the VMTN communities which can be found here. The script is actually based on modified version that was initially created by Justin Guidroz who blogged about it here.

Here is the snippet that would be included in the %firstboot in which does not require you to expose the root password as it is empty by default:

ESXi 4.1

import sys,re,os,urllib,urllib2
 
# connection info to MOB
url = "https://localhost/mob/?moid=ha-vnic-mgr&method=selectVnic"
username = "root"
password = ""
 
#auth
passman = urllib2.HTTPPasswordMgrWithDefaultRealm()
passman.add_password(None,url,username,password)
authhandler = urllib2.HTTPBasicAuthHandler(passman)
opener = urllib2.build_opener(authhandler)
urllib2.install_opener(opener)
 
#execute method
params = {'nicType':'management','device':'vmk0'}
e_params = urllib.urlencode(params)
req = urllib2.Request(url, e_params)
page = urllib2.urlopen(req).read()
__ENABLE_MGMT_INT__
 
python /tmp/enableVmkInterface.py

ESXi 4.1 Update 1 ( Requires CSRF code update)

cat > /tmp/enableVmkInterface.py << __ENABLE_MGMT_INT__
import sys,re,os,urllib,urllib2
 
# connection info to MOB
url = "https://localhost/mob/?moid=ha-vnic-mgr&method=selectVnic"
username = "root"
password = ""
 
# Create global variables
global passman,authhandler,opener,req,page,page_content,nonce,headers,cookie,params,e_params
 
#auth
passman = urllib2.HTTPPasswordMgrWithDefaultRealm()
passman.add_password(None,url,username,password)
authhandler = urllib2.HTTPBasicAuthHandler(passman)
opener = urllib2.build_opener(authhandler)
urllib2.install_opener(opener)
 
# Code to capture required page data and cookie required for post back to meet CSRF requirements  ###
req = urllib2.Request(url)
page = urllib2.urlopen(req)
page_content= page.read()
 
# regex to get the vmware-session-nonce value from the hidden form entry
reg = re.compile('name="vmware-session-nonce" type="hidden" value="?([^\s^"]+)"')
nonce = reg.search(page_content).group(1)
 
# get the page headers to capture the cookie
headers = page.info()
cookie = headers.get("Set-Cookie")
 
#execute method
params = {'vmware-session-nonce':nonce,'nicType':'management','device':'vmk0'}
e_params = urllib.urlencode(params)
req = urllib2.Request(url, e_params, headers={"Cookie":cookie})
page = urllib2.urlopen(req).read()
__ENABLE_MGMT_INT__
 
python /tmp/enableVmkInterface.py

As you can see, we first create the python script and then we execute it. This allows us to call other utilities within the Busybox console without having to specify the interpreter to be python, we can just use busybox as the interpreter.

Tip #7a Here is an alternative solution to enable management traffic type on ESXi - Another way to enable management traffic on ESXi

Tip #8

If you tried to configure NTP by echoing your NTP servers into /etc/ntpd.conf and restarting ntpd, you will notice that the changes do not take effect. The only way I have been able to get this to work is by issuing another reboot which is specified at the very end of the %firstboot which will then be picked up upon boot up by the host.

Tip #9

If you would like customize the DCUI Welcome Screen, take a look at my blog post How to add a splash of color to ESXi DCUI Welcome Screen.

Tip #10

If you want to update the default datastore name from "datastore1" to something more useful such as [hostname]-local-storage-1, you can use vim-cmd (vimsh) to do so. Here is the syntax for the command if you want to use the short hostname and append "-local-storage-1" (this should be done in the %firstboot section of your ks.cfg): vim-cmd hostsvc/datastore/rename datastore1 "$(hostname -s)-local-storage-1"

Tip #11

SNMP is another one of those configurations that can not be configured and started up via normal services as you would have done in classic ESX. You can make the appropriate edits to the configuration file and you will need to reboot the host for the changes to take affect just like NTP configurations. You will need to edit /etc/vmware/snmpd.xml and add that to your firstboot section. Here is an example of snmpd.xml file:

<config>
  <snmpsettings> 
    <communities>public1;private1</communities> 
    <enable>true</enable> 
    <port>163</port> 
    <targets>192.168.1.5 public1;192.168.1.6@163 private1</targets
  </snmpsettings>
</config>

Tip #12

A VMTN user recently posted an issue when applying patches during firstboot, that the init scripts were not being removed and the scripts continue to execute upon every reboot. The problem was that the boot.cfg were not being properly updated under /vmfs/volumes/Hypervisor{1,2}. I did some testing and found that if you created a second customization script and perform the patching as the very last step and issued a reboot, that you would not run into this problem.  Here is a small snippet of what your ks.cfg would like look with 2 custom init scripts, one configured at 998 and the other configured at 9999:

%firstboot --unsupported --interpreter=busybox --level=998
# do your customization
# in this section
 
%firstboot --unsupported --interpreter=busybox --level=9999
# do your patching
# in this section
 
#issue one final reboot
reboot
Tip #13

Here is a post on Automating Active Directory Domain Join in ESXi Kickstart

Tip #14

Here is a post on Automating Active Directory User Management in ESXi Kickstart As you can see, there are quite a few hacks I had to go through to get an equivalent kickstart build for ESXi 4.1 compared to classic ESX. I am sure there are other gotchas, but these are the ones I had encountered. Overall, ESXi 4.1 has greatly improved in terms of automating an unattended installation and configuration from ESXi 4.0, but there is definitely more work that needs to be done by VMware before users can easily transition from classic ESX to ESXi.

Tip #15
Here is a post on How to automatically add ESX(i) host to vCenter in Kickstart

In additional to VMware's documentation which is still limiting, here are additional tools and links that will be useful when creating your ks.cfg for ESXi 4.1:

  • http://communities.vmware.com/blogs/vmwareinsmb/2010/07/13/esxi-41-scripted-installation-via-pxe-and-kickstart
  • http://www.kendrickcoleman.com/index.php?/Tech-Blog/esxi-41-kickstart-install-wip.html
  • http://labs.vmware.com/flings/vmware-auto-deploy

Categories // Uncategorized Tags // ESXi 4.1, kickstart, ks.cfg, vSphere 4.1

Comments

  1. *protectedchadwick says

    09/16/2010 at 7:10 pm

    Wow.. we only have like 750+ esx host. Not to mention 300 are 3.5 . My next home lab is going to have to getting this build Esxi unattended dowm

    Reply
  2. *protectedDiederik says

    10/05/2010 at 9:09 am

    I'm trying to get tip 7 to work, keep getting this error:

    File "/tmp/enableVmkInterface.py", line 16, in
    params = {'nicType':Management,'device':vmk0}
    NameError: name 'Management' is not defined

    What other parameters can i fill in the nicType ? (i tried management (small caps) complete portgroupname etc)

    Reply
  3. *protectedWilliam says

    10/06/2010 at 1:49 am

    @Diederik,

    nicType describes the type of VMKernel traffic such as "management", "vmotion" and "faultTolerance", this is not the name of a portgroup. Make sure you have a valid vmkernel interface that has already been created and you need to specify the correct device (e.g. vmk0,vmk1,etc). Looking at the error, it sounds like you don't have a VMKernel interface and that is why you're getting the error.

    Reply
  4. *protectedKartik says

    10/10/2010 at 11:53 am

    Great Tips... Thank u so very much.

    Reply
  5. *protectedTimothy says

    10/13/2010 at 12:57 pm

    if you use "chvt 1" , the screen will change automatically to the screen where you can echo to into your firstboot script (that way you don't have to push alt+f1)

    Reply
  6. *protectedTimothy says

    10/24/2010 at 8:01 pm

    I played around with the python scripts you mentioned in step 7. Thought I share them with you guys...

    Probably most stuff can be done by using the vimsh cli but the scripts might be useful for other people trying out the MOB interface via python

    http://tendertechie.blogspot.com/2010/10/mob.html

    Reply
  7. *protectedJC says

    11/21/2010 at 1:20 am

    Thanks for Tip #12 ! I thought I was going crazy! :o)

    One thing maybe you could help with - I've got the esxupdate update bundle command working fine but I cannot get the host to exit maintenance mode after. No errors from the script and it works manually too. I've tried a separate level just for the vim-cmd /hostsvc/maintenance_mode_exit command as well as rebooting THEN exiting maintenance mode with no luck.

    Any thoughts or ideas?

    Thanks again!

    Reply
  8. *protectedChad says

    12/12/2010 at 10:10 pm

    So I am currently looking at deploying multiple ESXi servers to remote sites. This may be a long shot but ultimately what we would want to do is just rack the servers and when we power them on have someone at the site just type the site number into an input prompt and then from there have it completely automated and joined to vCenter with no interaction at all. This is a long shot and may not be so simple to do but would help us not like at Hyper-V or other solutions for virtualizing the sites. If you have any recommendations at all that would be great.

    Reply
  9. *protectedNava says

    01/03/2011 at 10:54 pm

    Hey William,

    I ran into this issue with ESXi kickstart install process where my system has several nic interfaces and when the VMkernel first comes alive and tries to download the ks.cfg file, it would try to do so using nic0 and fails immediately discontinuing the process. Nic2 is the only active interface and since this is on a chassis we develop there is no wires to move around either to make eth0 working.

    Any suggestions?

    Nava

    Reply
  10. *protectedWilliam says

    01/04/2011 at 1:50 am

    @Nava,

    Take a look at this VMware KB - http://kb.vmware.com/kb/1012248 and try BOOTIF flag to specify the interface.

    Reply
  11. *protecteddepping says

    02/21/2011 at 11:57 am

    the log location for vmfs will only work if and when you add "string" after the "DatastorePath" by the way 🙂

    Reply
  12. *protectedWilliam says

    02/21/2011 at 4:09 pm

    @depping,

    Thanks Duncan. I've fixed the syntax, must have somehow missed it.

    Reply
  13. *protectedroadfox says

    02/24/2011 at 6:46 am

    @chad

    Have a look at http://www.ultimatedeployment.org/
    If you can modify the bootp parameters at your remote sites, or install an uda aplliance per remote site, it'll be easy to deploy your esxi host.
    we are very succefully deploying 4.1 vsphere and win7 with UDA.

    Reply
  14. *protectedvmjfk says

    03/05/2011 at 12:57 am

    But what if you don't *want* to erase the first disk and install there? What if you don't know _which_ disk you want to install to? ks.cfg requires autopart or it won't work. All I want is for the server to boot from pxe and load the files, then let me choose which disk I want to use. Is there a boot command to do that, without using ks.cfg?

    Reply
  15. *protectedK. Chris Nakagaki (中垣浩一) says

    11/09/2011 at 9:29 pm

    Tip #15 link seems to be broken.

    Reply
  16. *protectedWilliam says

    11/10/2011 at 2:57 pm

    @Chris,

    Thanks, it's fixed now

    Reply
  17. *protectedAnonymous says

    10/18/2012 at 7:11 pm

    This line is not going to work with ESXi 5.1:
    HOSTNAME=$(nslookup "${IPADDR}" | grep Address | awk '{print $4}')

    The output format of nslookup has changed. Try:
    HOSTNAME=$(nslookup "${IPADDR}" | tail -1 | awk '{print $4}')

    Reply
    • *protectedWilliam says

      10/18/2012 at 10:20 pm

      @Anonymous,

      Thanks. I've fixed this on the ESXi 5.1 kickstart page (http://www.virtuallyghetto.com/2012/09/automating-esxi-51-kickstart-tips-tricks.html), you're actually posting in the ESXi 4.1 kickstart page

      Reply
  18. *protectedvishwanatha D R says

    08/04/2013 at 2:43 pm

    This comment has been removed by the author.

    Reply
  19. *protectedvishwanatha D R says

    08/04/2013 at 2:46 pm

    Hi,

    I am trying to deploy vAPP in specific cluster.

    My problem is, I will be knowing the cluster name where i can deploy the vAPP but as part of My .ovf description i need to select data store in the cluster where i am deploying.
    i need to select max free size datastore.

    please help on this;

    PowerCLI C:\Program Files (x86)\VMware\Infrastructure\vSphere PowerCLI> $ds=Get-Data
    store -VMHost yyyyyyy.jj.kk.com | select FreeSpaceGB | where

    wt shouold be criteria i should specify??

    vishwa

    Reply

Trackbacks

  1. Automating ESXi 5 Kickstart Tips & Tricks | virtuallyGhetto says:
    03/02/2014 at 6:27 pm

    […] are some minor changes with kickstarting ESXi 5.0 but the majority of your existing ESXi 4.1 kickstart configurations can be re-used with a few modifications. One of my goals during the vSphere 5.0 beta was to […]

    Reply
  2. Automating Active Directory Domain Join in ESX(i) Kickstart | virtuallyGhetto says:
    03/02/2014 at 7:45 pm

    […] The simple answer is yes; you can easily do so using the same trick found in tip #7 in Automating ESXi 4.1 Kickstart Tips & Tricks post which connects locally to the vSphere MOB using […]

    Reply
  3. Another way to enable management traffic on ESXi | virtuallyGhetto says:
    03/03/2014 at 9:31 am

    […] and connecting to the vSphere API locally on an ESXi host which is described in my blog article Automating ESXi 4.1 Kickstart Tips & Tricks Tip […]

    Reply
  4. Kickstart-ing ESXi | Think©Loud says:
    05/28/2014 at 6:24 am

    […] Automating ESXi 4.1 Kickstart Tips & Tricks […]

    Reply
  5. Using iOmega IX4-200d as DHCP, DNS, TFTP and PXE server » myvirtualcloud.net says:
    01/30/2017 at 8:10 am

    […] http://www.virtuallyghetto.com/2010/09/automating-esxi-41-kickstart-tips.html […]

    Reply

Thanks for the comment!Cancel reply

This site uses Akismet to reduce spam. Learn how your comment data is processed.

Search

Thank Author

Author

William is Distinguished Platform Engineering Architect in the VMware Cloud Foundation (VCF) Division at Broadcom. His primary focus is helping customers and partners build, run and operate a modern Private Cloud using the VMware Cloud Foundation (VCF) platform.

Connect

  • Bluesky
  • Email
  • GitHub
  • LinkedIn
  • Mastodon
  • Reddit
  • RSS
  • Twitter
  • Vimeo

Recent

  • USB Native Network Driver for ESXi supports Realtek RTL8157 & RTL8156BG 02/13/2026
  • Automating the Retrieval of VCF Installer Deployment Milestones 02/10/2026
  • Cross vCenter vMotion workloads from vSphere 7.0 to vSphere 9.0 02/09/2026
  • Installing Realtek Network Driver Fling using Free ESXi 8.0 Update 3e ISO 02/05/2026
  • Modern Kubernetes Visualization using Radar 02/01/2026

Advertisment

Privacy & Cookies: This site uses cookies. By continuing to use this website, you agree to their use.

To find out more, including how to control cookies, see here: Cookie Policy

Copyright WilliamLam.com © 2026