Friday, November 30, 2012

Automatic VLAN change in VMware View On windows 7

 this is good  scripts for the   Automatic VLAN   on vmware view 
http://myvirtualcloud.net/?p=1838&cpage=1#comment-150353
only issue i  had was making this work  on the windows  7  using psexec so i used  invoke command powershell  below are the  steps to make the script  work  on vmware view 


Needed to set on vcenter for powershell memory & Shells allowed for on vcenter server

set-item wsman:localhost\Shell\MaxMemoryPerShellMB 1024
winrm set winrm/config/winrs ‘@{MaxShellsPerUser=”50″}’
postsync script
# ——————————– Begin Script ————————————
# Load the VIM API
Write-Host $args[0]
Write-Host $args[1]
Add-PSSnapin VMware.VimAutomation.Core
# Connect to the VirtualCenter
connect-viserver $vcenterservername -User $vcenteruserid -Password $vcenterpassword
# RunFromGuest.ps1 passes the VMname and the VLAN information, then sets the VLAN accordingly
get-vm $args[0] | get-networkadapter | set-networkadapter -networkname $args[1] -confirm:$false
# Because we just disconnected the NIC and changed the VLAN, reboot the virtual machine
Write-Host $args[0]
restart-vmguest -vm $args[0] -confirm:$false
exit
# ——————————– End Script ————————————
# ——————————– Begin Script ————————————
start-sleep -seconds 15
# First get the name of the virtual machine and store it in the variable $vmName
$vmName = get-content env:computername
# Next, connect to the data source (in this case a simple CSV)
$obj = import-csv \\$vcenterserver\postsync\data.csv
# Finally, search the CSV for the virtual machine name and find the associated VLAN ID
foreach ($item in $obj)
{
if ($vmName -eq $item.vm)
{
# If we find a match, execute postsync.ps1 from the VirtualCenter server
$VLAN=$item.vlan
$pass = convertto-securestring “$vcenterpassword” -asplaintext -force
$mycred = new-object -typename System.Management.Automation.PSCredential -argumentlist “$$vcenteruserid”,$pass
Invoke-Command -computername $vcenterservername -Credential $mycred -scriptBlock {param($vmName,$VLAN) C:\postsync\postsync.ps1 $vmName $VLAN } -Argumentlist $vmName,$VLAN
}
}
# ——————————– End Script ————————————

Monday, July 9, 2012

CISCO UCS

Found a great article from Jibby  about the CISCO UCS  flexpod  showing all the  components. I would write in my next article about full automation using goucs  

http://jibbysununix.blogspot.com/2011_12_01_archive.html


Tuesday, July 3, 2012

Frontend Apache with Tomcat?

Many people has  asked me the same question again and  again  so its better to document it.

Took this from apache wiki http://wiki.apache.org/tomcat/FAQ/Connectors#Q3

Why should I integrate Apache with Tomcat? (or not)
There are many reasons to integrate Tomcat with Apache. And there are reasons why it should not be done too. Needless to say, everyone will disagree with the opinions here. With the performance of Tomcat 5 and 6, performance reasons become harder to justify. So here are the issues to discuss in integrating vs not.
  • Clustering. By using Apache as a front end you can let Apache act as a front door to your content to multiple Tomcat instances. If one of your Tomcats fails, Apache ignores it and your Sysadmin can sleep through the night. This point could be ignored if you use a hardware loadbalancer and Tomcat's clustering capabilities.
  • Clustering/Security. You can also use Apache as a front door to different Tomcats for different URL namespaces (/app1/, /app2/, /app3/, or virtual hosts). The Tomcats can then be each in a protected area and from a security point of view, you only need to worry about the Apache server. Essentially, Apache becomes a smart proxy server.
  • Security. This topic can sway one either way. Java has the security manager while Apache has a larger mindshare and more tricks with respect to security. I won't go into this in more detail, but let Google be your friend. Depending on your scenario, one might be better than the other. But also keep in mind, if you run Apache with Tomcat - you have two systems to defend, not one.
  • Add-ons. Adding on CGI, perl, PHP is very natural to Apache. Its slower and more of a kludge for Tomcat. Apache also has hundreds of modules that can be plugged in at will. Tomcat can have this ability, but the code hasn't been written yet.
  • Decorators! With Apache in front of Tomcat, you can perform any number of decorators that Tomcat doesn't support or doesn't have the immediate code support. For example, mod_headers, mod_rewrite, and mod_alias could be written for Tomcat, but why reinvent the wheel when Apache has done it so well?
  • Speed. Apache is faster at serving static content than Tomcat. But unless you have a high traffic site, this point is useless. But in some scenarios, tomcat can be faster than Apache httpd. So benchmark YOUR site. Tomcat can perform at httpd speeds when using the proper connector (APR with sendFile enabled). Speed should not be considered a factor when choosing between Apache httpd and Tomcat
  • Socket handling/system stability. Apache has better socket handling with respect to error conditions than Tomcat. The main reason is Tomcat must perform all its socket handling via the JVM which needs to be cross platform. The problem is socket optimization is a platform specific ordeal. Most of the time the java code is fine, but when you are also bombarded with dropped connections, invalid packets, invalid requests from invalid IP's, Apache does a better job at dropping these error conditions than JVM based program. (YMMV)