SlideShare a Scribd company logo
1 of 37
Download to read offline
Python

for Linux system administration




       (yes, this is a commercial)




              Vern Ceder
            Fort Wayne LUG
            Fort Wayne, IN
Instead of?

the “official” languages for sysamins



    bash* (and awk and sed)
       *or your favorite similar shell


                   perl
       (if you don't believe me,
             ask O'Reilly)
http://www.oreillyschool.com/courses/asac4/
A scripting language should

      handle input & output

 process text – search, replace,
      pattern matching, etc.

       traverse filesystems

use system utilities and libraries
              (glue)
What's wrong with
   bash & perl?



 Nothing, really...
bash


is a great glue language

pipes things like a champ

has a ton of utilities
  (the whole system, in fact)
awk and sed


handle strings brilliantly
perl


combines it all...
but...

  bash is a pain when things
          get complex

         sed is tricky

    perl makes my head hurt

(I always have rather liked awk)
So what about Python?

      handles strings well

        is a good “glue”

   “batteries included” → I/O,
         filesystem, etc

large collection of external libs
Python also

   is very readable
(and easy to maintain)

    is expressive

   is easy to grasp

is either OO (or not)

        is fun
everyone's doing it

        Redhat

        Ubuntu

        Google

   etc, etc, etc...
but...
         (there's always a “but”)


regular expressions aren't built-in

   not (quite) as common as perl
and let's talk about




the elephant in the room
indentation

yes, Python uses indentation
       to organize code

 it makes code more readable

it's no weirder than {} or @$%



         get over it
strings
some built-in string methods
   split             lower
   strip             upper
    join            isdigit
  replace          swapcase
    find          expandtabs
   count             center
startswith      encode/decode
 endswith            format
for example

             to do what wc does:
#!/usr/bin/env python

import sys
data = sys.stdin.read()
chars = len(data)
words = len(data.split())
lines = len(data.split('n'))
print ("{0}   {1}   {2}".format(lines, words, chars))

doc@paladin:~/work/olf$ ./wc.py < wc.py
12   22   189
or number of occurrences?
             in bash (not mine):
doc@pal:~/olf$ tr " " "n" <    wc.py | grep len | wc -w
3
                   in Python:
#!/usr/bin/env python
import sys
data = sys.stdin.read()
print data.count(sys.argv[1])

doc@paladin:~/work/olf$ ./num_occur.py len < wc.py
3
regular expressions

                   re module

         syntax similar to perl
import re
>>> re.findall("[Ll]en", "len is the Length")
['len', 'Len']
exception handling
y = 10
try:
    x = y / 0
except ZeroDivisionError, e:
    print e
integer division or modulo by zero
glue

 multiple ways to call other
programs and pipe the results
  sys.stdin, sys.stdout, sys.stderr

      os.system(), os.spawnl()

         subprocess.call()

         subprocess.Popen()
Modules: subprocess
from subprocess import *
p = Popen(["ls", "-l"], stdout=PIPE, stderr=PIPE)
out, err = p.communicate()
files, directories and more
        the os and sys modules
os.environ         sys.argv
os.getcwd          sys.stdin
os.chmod           sys.stdout
os.chown           sys.stderr
os.link            sys.platform
os.mkdir           sys.exit
os.remove
os.rename
Modules: os

                os.walk()
import os
>>> for x in os.walk('.'):
...     print x
...
('.', ['emptydir'], [ 'chinese-python-
poster.jpg', 'olf_proposal.txt', 'wc.py',
'olf.odp', 'shell.png', 'olf.txt',
'Pil.gif', 'adminscripting.png',
'num_occur.py'])
('./emptydir', [], [])
Modules: os.path

     exists
     getmtime
     isfile
     isdir
     islink
     ismount
     samefile
     split
command line arguments

           sys.argv
      list of all arguments

           optparse
  parsing all types of arguments

  returns options and parameters

         automatic help
Modules: others

databases – sqlite3 and others

             fork

          threading
ssh – paramiko
#!/usr/bin/env python
import paramiko

hostname = 'localhost'
port = 22
username = 'test'
password = 'password'

paramiko.util.log_to_file('paramiko.log')
    s = paramiko.SSHClient()
    s.load_system_host_keys()
    s.connect(hostname, port, username, password)
    stdin, stdout, stderr = s.exec_command('ifconfig')
    print stdout.read()
    s.close()
daemons

               python-daemon
import daemon
from spam import main_program
with daemon.DaemonContext():
main_program
ctypes
         load and use C libraries
          also works with Windows DLL's

>>> from ctypes import *
>>> libc = CDLL("libc.so.6")
>>> libc.printf("hello %sn", "Python")
hello Python
13
>>> print libc.time(None)
1253757776
>>> import datetime
>>> datetime.datetime.fromtimestamp(libc.time(None))
datetime.datetime(2009, 9, 23, 22, 5, 56)
A 2 line HTTP server
from  http.server import HTTPServer,
              SimpleHTTPRequestHandler
server = HTTPServer(("",8000),
           SimpleHTTPRequestHandler)
server.serve_forever()
What about Python 3?

it's a better language than 2.x

  it's not backward compatible

it's supported by the developers

         it's the future

it's not here (for sysadmins) yet
ipython, the uber shell

             extensive history

        usable as a system shell

        http://ipython.scipy.org
In [1]: print "hello"
------> print("hello")
hello

In [2]: ls
 adminscripting.png      olf.odp   Pil.gif
nd
Quick Python Book, 2            ed

           covering Python 3

        due out late this year
          http://www.manning.com/ceder
World's largest Python conference
             Talks

                         PyCon 2010
                                                             Open Space
         Tutorials
                                                             Hands-On Lab
        Lightning
          Talks           Feb. 17-25                          Exhibit Hall

        Keynotes
                          Atlanta, GA                           Sprints


                            NOW with
                         Poster sessions!




                         us.pycon.org
Photo: james.rintamaki
License: Attribution-
Share Alike 2.0
Generic
Resources
                  & contact info

    Python for Unix and Linux System Administration,
     Noah Gift, Jeremy M. Jones, O'Reilly Media 2008

          Pro Python System Administration,
      Rytis Sileika, Apress, (not yet published)

   “Python for system administrators”, James Knowlton,
                 IBM DeveloperWorks, 2007
http://www.ibm.com/developerworks/aix/library/au-python/

   Python Cookbook, Martelli, Ravenscroft & Ascher,
                  O'Reilly Media 2005
Contact info


http://tech.canterburyschool.org/tech/VernCeder

         http://www.manning.com/ceder

               vceder@gmail.com

More Related Content

What's hot

클라우드 환경에서 비즈니스 애플리케이션의 성능 통합 모니터링 방안::류길현::AWS Summit Seoul 2018
클라우드 환경에서 비즈니스 애플리케이션의 성능 통합 모니터링 방안::류길현::AWS Summit Seoul 2018 클라우드 환경에서 비즈니스 애플리케이션의 성능 통합 모니터링 방안::류길현::AWS Summit Seoul 2018
클라우드 환경에서 비즈니스 애플리케이션의 성능 통합 모니터링 방안::류길현::AWS Summit Seoul 2018
Amazon Web Services Korea
 

What's hot (20)

Automation with ansible
Automation with ansibleAutomation with ansible
Automation with ansible
 
Terraform
TerraformTerraform
Terraform
 
Introduction to AWS IAM
Introduction to AWS IAMIntroduction to AWS IAM
Introduction to AWS IAM
 
K8s on AWS - Introducing Amazon EKS
K8s on AWS - Introducing Amazon EKSK8s on AWS - Introducing Amazon EKS
K8s on AWS - Introducing Amazon EKS
 
Identity and Access Management: The First Step in AWS Security
Identity and Access Management: The First Step in AWS SecurityIdentity and Access Management: The First Step in AWS Security
Identity and Access Management: The First Step in AWS Security
 
AWS Code Services
AWS Code ServicesAWS Code Services
AWS Code Services
 
클라우드 환경에서 비즈니스 애플리케이션의 성능 통합 모니터링 방안::류길현::AWS Summit Seoul 2018
클라우드 환경에서 비즈니스 애플리케이션의 성능 통합 모니터링 방안::류길현::AWS Summit Seoul 2018 클라우드 환경에서 비즈니스 애플리케이션의 성능 통합 모니터링 방안::류길현::AWS Summit Seoul 2018
클라우드 환경에서 비즈니스 애플리케이션의 성능 통합 모니터링 방안::류길현::AWS Summit Seoul 2018
 
AWS 기반 클라우드 아키텍처 모범사례 - 삼성전자 개발자 포털/개발자 워크스페이스 - 정영준 솔루션즈 아키텍트, AWS / 유현성 수석,...
AWS 기반 클라우드 아키텍처 모범사례 - 삼성전자 개발자 포털/개발자 워크스페이스 - 정영준 솔루션즈 아키텍트, AWS / 유현성 수석,...AWS 기반 클라우드 아키텍처 모범사례 - 삼성전자 개발자 포털/개발자 워크스페이스 - 정영준 솔루션즈 아키텍트, AWS / 유현성 수석,...
AWS 기반 클라우드 아키텍처 모범사례 - 삼성전자 개발자 포털/개발자 워크스페이스 - 정영준 솔루션즈 아키텍트, AWS / 유현성 수석,...
 
Cloud Migration Paths: Kubernetes, IaaS, or DBaaS
Cloud Migration Paths: Kubernetes, IaaS, or DBaaSCloud Migration Paths: Kubernetes, IaaS, or DBaaS
Cloud Migration Paths: Kubernetes, IaaS, or DBaaS
 
복잡한 권한신청문제 ConsoleMe로 해결하기 - 손건 (AB180) :: AWS Community Day Online 2021
복잡한 권한신청문제 ConsoleMe로 해결하기 - 손건 (AB180) :: AWS Community Day Online 2021복잡한 권한신청문제 ConsoleMe로 해결하기 - 손건 (AB180) :: AWS Community Day Online 2021
복잡한 권한신청문제 ConsoleMe로 해결하기 - 손건 (AB180) :: AWS Community Day Online 2021
 
Security hub workshop
Security hub workshopSecurity hub workshop
Security hub workshop
 
20191125 Container Security
20191125 Container Security20191125 Container Security
20191125 Container Security
 
[AWS Builders] 프리티어 서비스부터 계정 보안까지
[AWS Builders] 프리티어 서비스부터 계정 보안까지[AWS Builders] 프리티어 서비스부터 계정 보안까지
[AWS Builders] 프리티어 서비스부터 계정 보안까지
 
CI/CD on AWS
CI/CD on AWSCI/CD on AWS
CI/CD on AWS
 
AWS Control Tower
AWS Control TowerAWS Control Tower
AWS Control Tower
 
DEV323_Introduction to the AWS CLI
DEV323_Introduction to the AWS CLIDEV323_Introduction to the AWS CLI
DEV323_Introduction to the AWS CLI
 
AWS CDK introduction
AWS CDK introductionAWS CDK introduction
AWS CDK introduction
 
Introduction to AWS Organizations
Introduction to AWS OrganizationsIntroduction to AWS Organizations
Introduction to AWS Organizations
 
Best practices for ansible
Best practices for ansibleBest practices for ansible
Best practices for ansible
 
AWS WAF
AWS WAFAWS WAF
AWS WAF
 

Viewers also liked

Server Administration in Python with Fabric, Cuisine and Watchdog
Server Administration in Python with Fabric, Cuisine and WatchdogServer Administration in Python with Fabric, Cuisine and Watchdog
Server Administration in Python with Fabric, Cuisine and Watchdog
ConFoo
 
Integrando mis librerías C++ con Python
Integrando mis librerías C++ con PythonIntegrando mis librerías C++ con Python
Integrando mis librerías C++ con Python
Carlos Gustavo Ruiz
 
Real world Django deployment using Chef
Real world Django deployment using ChefReal world Django deployment using Chef
Real world Django deployment using Chef
coderanger
 
Automated Deployment with Fabric
Automated Deployment with FabricAutomated Deployment with Fabric
Automated Deployment with Fabric
tanihito
 
Python Deployment with Fabric
Python Deployment with FabricPython Deployment with Fabric
Python Deployment with Fabric
andymccurdy
 

Viewers also liked (20)

Python and sysadmin I
Python and sysadmin IPython and sysadmin I
Python and sysadmin I
 
Python for-unix-and-linux-system-administration
Python for-unix-and-linux-system-administrationPython for-unix-and-linux-system-administration
Python for-unix-and-linux-system-administration
 
Programming Under Linux In Python
Programming Under Linux In PythonProgramming Under Linux In Python
Programming Under Linux In Python
 
Server Administration in Python with Fabric, Cuisine and Watchdog
Server Administration in Python with Fabric, Cuisine and WatchdogServer Administration in Python with Fabric, Cuisine and Watchdog
Server Administration in Python with Fabric, Cuisine and Watchdog
 
PyOWM - my first open source project
PyOWM - my first open source projectPyOWM - my first open source project
PyOWM - my first open source project
 
Programación Segura en python. Owasp Venezuela
Programación Segura en python. Owasp  VenezuelaProgramación Segura en python. Owasp  Venezuela
Programación Segura en python. Owasp Venezuela
 
Introduction to the rapid prototyping with python and linux for embedded systems
Introduction to the rapid prototyping with python and linux for embedded systemsIntroduction to the rapid prototyping with python and linux for embedded systems
Introduction to the rapid prototyping with python and linux for embedded systems
 
Integrando mis librerías C++ con Python
Integrando mis librerías C++ con PythonIntegrando mis librerías C++ con Python
Integrando mis librerías C++ con Python
 
Real world Django deployment using Chef
Real world Django deployment using ChefReal world Django deployment using Chef
Real world Django deployment using Chef
 
Linux system administration - part-2
Linux system administration - part-2Linux system administration - part-2
Linux system administration - part-2
 
Python en Android,Charla del FUDcon Latam 2012
Python en Android,Charla del FUDcon Latam 2012Python en Android,Charla del FUDcon Latam 2012
Python en Android,Charla del FUDcon Latam 2012
 
Automated Deployment with Fabric
Automated Deployment with FabricAutomated Deployment with Fabric
Automated Deployment with Fabric
 
Final Internship presentation
Final Internship presentationFinal Internship presentation
Final Internship presentation
 
TDC2016SP - Trilha Linux Embarcado
TDC2016SP - Trilha Linux EmbarcadoTDC2016SP - Trilha Linux Embarcado
TDC2016SP - Trilha Linux Embarcado
 
Final Internship Presentation
Final Internship Presentation Final Internship Presentation
Final Internship Presentation
 
Architecting a Scalable Hadoop Platform: Top 10 considerations for success
Architecting a Scalable Hadoop Platform: Top 10 considerations for successArchitecting a Scalable Hadoop Platform: Top 10 considerations for success
Architecting a Scalable Hadoop Platform: Top 10 considerations for success
 
Python Deployment with Fabric
Python Deployment with FabricPython Deployment with Fabric
Python Deployment with Fabric
 
Internship final presentation GraphicPeople
Internship final presentation GraphicPeopleInternship final presentation GraphicPeople
Internship final presentation GraphicPeople
 
Where to Deploy Hadoop: Bare Metal or Cloud?
Where to Deploy Hadoop: Bare Metal or Cloud? Where to Deploy Hadoop: Bare Metal or Cloud?
Where to Deploy Hadoop: Bare Metal or Cloud?
 
20150306 파이썬기초 IPython을이용한프로그래밍_이태영
20150306 파이썬기초 IPython을이용한프로그래밍_이태영20150306 파이썬기초 IPython을이용한프로그래밍_이태영
20150306 파이썬기초 IPython을이용한프로그래밍_이태영
 

Similar to Python for Linux System Administration

PyCon 2013 : Scripting to PyPi to GitHub and More
PyCon 2013 : Scripting to PyPi to GitHub and MorePyCon 2013 : Scripting to PyPi to GitHub and More
PyCon 2013 : Scripting to PyPi to GitHub and More
Matt Harrison
 
An Overview Of Python With Functional Programming
An Overview Of Python With Functional ProgrammingAn Overview Of Python With Functional Programming
An Overview Of Python With Functional Programming
Adam Getchell
 
Introduction to Python 01-08-2023.pon by everyone else. . Hence, they must be...
Introduction to Python 01-08-2023.pon by everyone else. . Hence, they must be...Introduction to Python 01-08-2023.pon by everyone else. . Hence, they must be...
Introduction to Python 01-08-2023.pon by everyone else. . Hence, they must be...
DRVaibhavmeshram1
 
System Calls.pptxnsjsnssbhsbbebdbdbshshsbshsbbs
System Calls.pptxnsjsnssbhsbbebdbdbshshsbshsbbsSystem Calls.pptxnsjsnssbhsbbebdbdbshshsbshsbbs
System Calls.pptxnsjsnssbhsbbebdbdbshshsbshsbbs
ashukiller7
 
Program Assignment Process ManagementObjective This program a.docx
Program Assignment  Process ManagementObjective This program a.docxProgram Assignment  Process ManagementObjective This program a.docx
Program Assignment Process ManagementObjective This program a.docx
wkyra78
 
Workshop presentation hands on r programming
Workshop presentation hands on r programmingWorkshop presentation hands on r programming
Workshop presentation hands on r programming
Nimrita Koul
 

Similar to Python for Linux System Administration (20)

Python1
Python1Python1
Python1
 
Python_intro.ppt
Python_intro.pptPython_intro.ppt
Python_intro.ppt
 
PenTest using Python By Purna Chander
PenTest using Python By Purna ChanderPenTest using Python By Purna Chander
PenTest using Python By Purna Chander
 
Developing IT infrastructures with Puppet
Developing IT infrastructures with PuppetDeveloping IT infrastructures with Puppet
Developing IT infrastructures with Puppet
 
Advanced Python Tutorial | Learn Advanced Python Concepts | Python Programmin...
Advanced Python Tutorial | Learn Advanced Python Concepts | Python Programmin...Advanced Python Tutorial | Learn Advanced Python Concepts | Python Programmin...
Advanced Python Tutorial | Learn Advanced Python Concepts | Python Programmin...
 
Python for Penetration testers
Python for Penetration testersPython for Penetration testers
Python for Penetration testers
 
PyCon 2013 : Scripting to PyPi to GitHub and More
PyCon 2013 : Scripting to PyPi to GitHub and MorePyCon 2013 : Scripting to PyPi to GitHub and More
PyCon 2013 : Scripting to PyPi to GitHub and More
 
Introduction to clojure
Introduction to clojureIntroduction to clojure
Introduction to clojure
 
Raspberry pi Part 4
Raspberry pi Part 4Raspberry pi Part 4
Raspberry pi Part 4
 
An Overview Of Python With Functional Programming
An Overview Of Python With Functional ProgrammingAn Overview Of Python With Functional Programming
An Overview Of Python With Functional Programming
 
Python: an introduction for PHP webdevelopers
Python: an introduction for PHP webdevelopersPython: an introduction for PHP webdevelopers
Python: an introduction for PHP webdevelopers
 
Introduction to Python 01-08-2023.pon by everyone else. . Hence, they must be...
Introduction to Python 01-08-2023.pon by everyone else. . Hence, they must be...Introduction to Python 01-08-2023.pon by everyone else. . Hence, they must be...
Introduction to Python 01-08-2023.pon by everyone else. . Hence, they must be...
 
Introduction to PowerShell
Introduction to PowerShellIntroduction to PowerShell
Introduction to PowerShell
 
Hack Like It's 2013 (The Workshop)
Hack Like It's 2013 (The Workshop)Hack Like It's 2013 (The Workshop)
Hack Like It's 2013 (The Workshop)
 
System Calls.pptxnsjsnssbhsbbebdbdbshshsbshsbbs
System Calls.pptxnsjsnssbhsbbebdbdbshshsbshsbbsSystem Calls.pptxnsjsnssbhsbbebdbdbshshsbshsbbs
System Calls.pptxnsjsnssbhsbbebdbdbshshsbshsbbs
 
Program Assignment Process ManagementObjective This program a.docx
Program Assignment  Process ManagementObjective This program a.docxProgram Assignment  Process ManagementObjective This program a.docx
Program Assignment Process ManagementObjective This program a.docx
 
Presentation of Python, Django, DockerStack
Presentation of Python, Django, DockerStackPresentation of Python, Django, DockerStack
Presentation of Python, Django, DockerStack
 
Systemcall1
Systemcall1Systemcall1
Systemcall1
 
Workshop presentation hands on r programming
Workshop presentation hands on r programmingWorkshop presentation hands on r programming
Workshop presentation hands on r programming
 
Pemrograman Python untuk Pemula
Pemrograman Python untuk PemulaPemrograman Python untuk Pemula
Pemrograman Python untuk Pemula
 

Python for Linux System Administration

  • 1. Python for Linux system administration (yes, this is a commercial) Vern Ceder Fort Wayne LUG Fort Wayne, IN
  • 2. Instead of? the “official” languages for sysamins bash* (and awk and sed) *or your favorite similar shell perl (if you don't believe me, ask O'Reilly)
  • 4. A scripting language should handle input & output process text – search, replace, pattern matching, etc. traverse filesystems use system utilities and libraries (glue)
  • 5. What's wrong with bash & perl? Nothing, really...
  • 6. bash is a great glue language pipes things like a champ has a ton of utilities (the whole system, in fact)
  • 7. awk and sed handle strings brilliantly
  • 9. but... bash is a pain when things get complex sed is tricky perl makes my head hurt (I always have rather liked awk)
  • 10. So what about Python? handles strings well is a good “glue” “batteries included” → I/O, filesystem, etc large collection of external libs
  • 11. Python also is very readable (and easy to maintain) is expressive is easy to grasp is either OO (or not) is fun
  • 12. everyone's doing it Redhat Ubuntu Google etc, etc, etc...
  • 13. but... (there's always a “but”) regular expressions aren't built-in not (quite) as common as perl
  • 14. and let's talk about the elephant in the room
  • 15. indentation yes, Python uses indentation to organize code it makes code more readable it's no weirder than {} or @$% get over it
  • 16. strings some built-in string methods split lower strip upper join isdigit replace swapcase find expandtabs count center startswith encode/decode endswith format
  • 17. for example to do what wc does: #!/usr/bin/env python import sys data = sys.stdin.read() chars = len(data) words = len(data.split()) lines = len(data.split('n')) print ("{0} {1} {2}".format(lines, words, chars)) doc@paladin:~/work/olf$ ./wc.py < wc.py 12 22 189
  • 18. or number of occurrences? in bash (not mine): doc@pal:~/olf$ tr " " "n" < wc.py | grep len | wc -w 3 in Python: #!/usr/bin/env python import sys data = sys.stdin.read() print data.count(sys.argv[1]) doc@paladin:~/work/olf$ ./num_occur.py len < wc.py 3
  • 19. regular expressions re module syntax similar to perl import re >>> re.findall("[Ll]en", "len is the Length") ['len', 'Len']
  • 20. exception handling y = 10 try: x = y / 0 except ZeroDivisionError, e: print e integer division or modulo by zero
  • 21. glue multiple ways to call other programs and pipe the results sys.stdin, sys.stdout, sys.stderr os.system(), os.spawnl() subprocess.call() subprocess.Popen()
  • 22. Modules: subprocess from subprocess import * p = Popen(["ls", "-l"], stdout=PIPE, stderr=PIPE) out, err = p.communicate()
  • 23. files, directories and more the os and sys modules os.environ sys.argv os.getcwd sys.stdin os.chmod sys.stdout os.chown sys.stderr os.link sys.platform os.mkdir sys.exit os.remove os.rename
  • 24. Modules: os os.walk() import os >>> for x in os.walk('.'): ... print x ... ('.', ['emptydir'], [ 'chinese-python- poster.jpg', 'olf_proposal.txt', 'wc.py', 'olf.odp', 'shell.png', 'olf.txt', 'Pil.gif', 'adminscripting.png', 'num_occur.py']) ('./emptydir', [], [])
  • 25. Modules: os.path exists getmtime isfile isdir islink ismount samefile split
  • 26. command line arguments sys.argv list of all arguments optparse parsing all types of arguments returns options and parameters automatic help
  • 27. Modules: others databases – sqlite3 and others fork threading
  • 28. ssh – paramiko #!/usr/bin/env python import paramiko hostname = 'localhost' port = 22 username = 'test' password = 'password' paramiko.util.log_to_file('paramiko.log') s = paramiko.SSHClient() s.load_system_host_keys() s.connect(hostname, port, username, password) stdin, stdout, stderr = s.exec_command('ifconfig') print stdout.read() s.close()
  • 29. daemons python-daemon import daemon from spam import main_program with daemon.DaemonContext(): main_program
  • 30. ctypes load and use C libraries also works with Windows DLL's >>> from ctypes import * >>> libc = CDLL("libc.so.6") >>> libc.printf("hello %sn", "Python") hello Python 13 >>> print libc.time(None) 1253757776 >>> import datetime >>> datetime.datetime.fromtimestamp(libc.time(None)) datetime.datetime(2009, 9, 23, 22, 5, 56)
  • 31. A 2 line HTTP server from http.server import HTTPServer, SimpleHTTPRequestHandler server = HTTPServer(("",8000), SimpleHTTPRequestHandler) server.serve_forever()
  • 32. What about Python 3? it's a better language than 2.x it's not backward compatible it's supported by the developers it's the future it's not here (for sysadmins) yet
  • 33. ipython, the uber shell extensive history usable as a system shell http://ipython.scipy.org In [1]: print "hello" ------> print("hello") hello In [2]: ls adminscripting.png olf.odp Pil.gif
  • 34. nd Quick Python Book, 2 ed covering Python 3 due out late this year http://www.manning.com/ceder
  • 35. World's largest Python conference Talks PyCon 2010 Open Space Tutorials Hands-On Lab Lightning Talks Feb. 17-25 Exhibit Hall Keynotes Atlanta, GA Sprints NOW with Poster sessions! us.pycon.org Photo: james.rintamaki License: Attribution- Share Alike 2.0 Generic
  • 36. Resources & contact info Python for Unix and Linux System Administration, Noah Gift, Jeremy M. Jones, O'Reilly Media 2008 Pro Python System Administration, Rytis Sileika, Apress, (not yet published) “Python for system administrators”, James Knowlton, IBM DeveloperWorks, 2007 http://www.ibm.com/developerworks/aix/library/au-python/ Python Cookbook, Martelli, Ravenscroft & Ascher, O'Reilly Media 2005
  • 37. Contact info http://tech.canterburyschool.org/tech/VernCeder http://www.manning.com/ceder vceder@gmail.com