设为首页 收藏本站
查看: 1218|回复: 0

Powershell 之管理Linux服务器

[复制链接]
累计签到:1 天
连续签到:1 天
发表于 2016-11-29 08:46:15 | 显示全部楼层 |阅读模式
PS本身是基于.NET框架的脚本开发工具,要想直接在Linux上运行,那几乎是不可能的。
了解Ansible的同学应该都知道其原理,PS也一样可以实现其相同的功能,要想完全拷贝,还是要下一番功夫的,这里呢只是简单介绍通过PS远程连接到Linux服务器。

   PS要连接Linux服务器,我们需要先下载SSH模块,请下载附件,成功下载后请将其进行注册(直接放到 C:\Windows\System32\WindowsPowerShell\v1.0\Modules),再通过命令验证是否成功
1
import-model posh-ssh



posh-ssh模块支持很多功能,这里只写两个,一个是SSH Command,一个是SSH SFTP。

SSH SESSION
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
#
#使用SSH协议连接服务器
#return Object @session
#
function ssh-connection{
    param(
        [string][alias('s')]$computer,
        [int][alias('p')]$port=22,
        [string][alias('u')]$user,
        [string][alias('pw')]$pwd
    )
    #
    #检查是否有配置连接信息
    #
    if($computer -eq $null -or $user -eq $null -or $pwd -eq $null){
        Write-Warning "Useage: conn -s ComputerName|IPAddress [-p Port] -u Username -pw Password"
        exit 1
    }
    #
    #检查机器名称是否规范
    #
    $computer=check -s $computer
    #if(!($session=Get-SSHSession|?{$_.host -eq $computer})){
    $password = ConvertTo-SecureString $pwd -AsPlainText -Force
    $Credential = New-Object System.Management.Automation.PSCredential($user,$password)
    $session=
    try{
        New-SshSession -ComputerName $computer -Port $port -Credential $Credential -AcceptKey
        Write-Host "A new ssh session has created,user $user logon on $computer" -fore Green
    }catch{
        Write-Error $Error[0]
        #Write-Error "Can't ssh connection this server $computer,pls check."
        exit 1
    }
    #}
    return $session

}




SFTP-SESSION
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
#
#使用SFTP协议连接服务器
#return Object @session
#
function sftp-connection{
    param(
        [string][alias('s')]$computer,
        [int][alias('p')]$port=22,
        [string][alias('u')]$user,
        [string][alias('pw')]$pwd
    )
    #
    #检查是否有配置连接信息
    #
    if($computer -eq $null -or $user -eq $null -or $pwd -eq $null){
        Write-Warning "Useage: sftp-connection -s ComputerName|IPAddress [-p Port] -u Username -pw Password"
        exit 1
    }
    #
    #检查机器名称是否规范
    #
    $computer=check -s $computer
    #if(!($session=Get-SSHSession|?{$_.host -eq $computer})){
    $password = ConvertTo-SecureString $pwd -AsPlainText -Force
    $Credential = New-Object System.Management.Automation.PSCredential($user,$password)
    $session=
    try{
        New-SFTPSession -ComputerName $computer -Port $port -Credential $Credential -AcceptKey
        Write-Host "A new sftp session has connected,user $user logon on $computer!" -fore Green
    }catch{
        Write-Error "Can't sftp connection this server $computer,pls check."
        exit 1
    }
    #}
    return $session

}




在使用过程中为了防止建立多个SESSION的情况,写了一个判断当前服务器是否存在SESSION的脚本,如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
#
#检查SSH连接是否存在,如不存在则创建会话
#return Object @session
#

function IsConnectionned{
    switch($args[0]){
        'ssh' {
            $session=Get-SSHSession|?{$_.host -eq $computer}
            if(! $session){
                ssh-connection -s $computer -u $user -pw $passwd
            }else{
                if($session.gettype().isarray){
                    #如果当前存在多个Session连接,则只保留其中一个
                    for($i=1;$i -lt $session.count;$i++){
                        try{
                            $sessionid=$session[$i].sessionid
                            Remove-SSHSession -SessionId $sessionid
                            Write-Host "A ssh session has removed,sessionID is $sessionid" -fore Green
                        }catch{
                            writelog $error[0]
                        }
                    }
                    $session=$session[0]
                }
            }
            return $session
        }
        'sftp' {
            $session=Get-SFTPSession|?{$_.host -eq $computer}
            if(! $session){
                $session=sftp-connection -s $computer -u $user -pw $passwd
            }else{
                if($session.gettype().isarray){
                    #如果当前存在多个Session连接,则只保留其中一个
                    for($i=1;$i -lt $session.count;$i++){
                        try{
                            $sessionid=$session[$i].sessionid
                            Remove-SSHSession -SessionId $sessionid
                            Write-Host "A ssh session has removed,sessionID is $sessionid" -fore Green
                        }catch{
                            writelog $error[0]
                        }
                    }
                    $session=$session[0]
                }
            }
            return $session
        }
    }

}




1
2
3
4
5
IsConnectionned 接受两个参数,一个是ssh,一个为sftp,ssh可以直接运行shell命令,sftp则为上传/下载文件

调用方法

IsConnectionned ssh|sftp




在Linux中,获取到的任何信息都是字符串,如果要更好的理解内容,需要通过awk或sed等工具进行处理。

这里我从Linux中获取到的用户信息,进行了对象化处理。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
function Shell{
    param(
        $command
    )
    $session=IsConnectionned ssh
    $r=Invoke-SSHCommand -SSHSession $session -Command $command
    $r=$r.Output -split "\n"
    #Remove-SSHSession -SSHSession $session|Out-Null
    #Write-Host "Return follow message:" -fore Yellow
    return $r
}

function Get-LinuxUser{
    $session=IsConnectionned ssh
    $r=Invoke-SSHCommand -SSHSession $session -Command "cat /etc/passwd"
    #Remove-SSHSession -SSHSession $session|Out-Null
    #Write-Host "Return follow message:" -fore Yellow
    $r = ($r.Output -split "\n")
    $arr=New-Object System.Collections.ArrayList
    foreach($u in $r){
        $u=$u -split ":"
        $psobject = New-Object psobject
        Add-Member -MemberType NoteProperty -Name Server -Value $computer -InputObject $psobject
        Add-Member -MemberType NoteProperty -Name UserName -Value $u[0] -InputObject $psobject
        Add-Member -MemberType NoteProperty -Name Password -Value $u[1] -InputObject $psobject
        Add-Member -MemberType NoteProperty -Name UserUID -Value $u[2] -InputObject $psobject
        Add-Member -MemberType NoteProperty -Name UserGID -Value $u[3] -InputObject $psobject
        Add-Member -MemberType NoteProperty -Name Comment  -Value $u[4] -InputObject $psobject
        Add-Member -MemberType NoteProperty -Name HomeDirectory -Value $u[5] -InputObject $psobject
        Add-Member -MemberType NoteProperty -Name Shell -Value $u[6] -InputObject $psobject
        [void]$arr.add($psobject)
    }
    return $arr
    Remove-Variable $u
    Remove-Variable $psobject
    Remove-Variable $arr
}

function Get-LinuxFileInfo{
    param($filename)
    if(-not([string]::IsNullOrEmpty($filename)) -and ($filename -notmatch "\\")){
        $command="ls -l --full-time $filename|awk " + "'" + '{print ' + '$1' + ','+ '$2'+ ',' + '$3'+ ',' + '$4'+ ',' + '$5'+ ',' + '$6'+ ',' + '$7'+ ',' + '$8'+ ',' + '$9' +'} ' + "'"
        $result=shell $command
        $reArray=$result -split '\n'
        $fileInfoList=New-Object System.Collections.ArrayList
        foreach($re in $reArray){
            if($re -eq ""){
                break
            }
            $re=$re -split ' '
            $re[6]=($re[6] -split '\.')[0]
            $psobject=New-Object psobject
            Add-Member -MemberType NoteProperty -Name 服务器 -Value $computer -InputObject $psobject
            Add-Member -MemberType NoteProperty -Name 权限 -Value $re[0] -InputObject $psobject
            Add-Member -MemberType NoteProperty -Name 文件数 -Value $re[1] -InputObject $psobject
            Add-Member -MemberType NoteProperty -Name 用户 -Value $re[2] -InputObject $psobject
            Add-Member -MemberType NoteProperty -Name 组 -Value $re[3] -InputObject $psobject
            Add-Member -MemberType NoteProperty -Name 大小 -Value $re[4] -InputObject $psobject
            Add-Member -MemberType NoteProperty -Name 日期 -Value $re[5] -InputObject $psobject
            Add-Member -MemberType NoteProperty -Name 时间 -Value $re[6] -InputObject $psobject
            Add-Member -MemberType NoteProperty -Name 时区 -Value $re[7] -InputObject $psobject
            Add-Member -MemberType NoteProperty -Name 文件名 -Value $re[8] -InputObject $psobject
            [void]$fileInfoList.add($psobject)
        }
        return $fileInfoList
    }else{
        Write-Warning "格式不正确或未指定Linux地址"
        exit 1
    }
}



除了用户信息外,还可以扩展其他内容,以后通过Powershell查看Linux信息,也是如此easy。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
上传文件到Linux服务器

function Upload-ToLinux{
    param(
        [alias('local')]$localPath,
        [alias('remote')]$remotePath
    )
    #targetPath格式检查
    if($remotePath -notmatch "/$"){
        Write-Warning "RemotePath 格式错误,请以/结尾"
        exit 1
    }
    $sftpsession=IsConnectionned "sftp"
    $r=Test-SFTPPath -SFTPSession $sftpsession $remotePath

    if((Test-Path $localPath) -and $r){
        if(isDirectory $localPath){
            #sourcePath格式检查
            if($localPath -notmatch "\\$"){
                Write-Warning "sourcePath 格式错误,请以\结尾"
                exit 1
            }
            $password = ConvertTo-SecureString $passwd -AsPlainText -Force
            $Credential = New-Object System.Management.Automation.PSCredential($user,$password)
            Set-SCPFolder -ComputerName $computer -Credential $Credential -LocalFolder $localPath -RemoteFolder $remotePath -AcceptKey
        }
        if(isFile $localPath){
            Set-SFTPFile  -SFTPSession $sftpsession -LocalFile $localPath* -RemotePath $remotePath -Overwrite
        }
    }else{
        Write-Warning "[本地路径] 或 [远程路径] 不存在"
        exit 1
    }

    #Remove-SFTPSession -SFTPSession $sftpsession|Out-Null
}




1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
从Linux上下载文件

function Download-FromLinux{
    param(
        [alias('remote')]$remotePath,
        [alias('local')]$localPath

    )
    if($remotePath -eq $null -or $localPath -eq $null){
        Write-Warning "Usage: Download-FromLinx -remote RemotePath -local LocalPath"
        exit 1
    }
    if(! (Test-Path $localPath)){
        [void](mkdir $localPath)
    }
    $password = ConvertTo-SecureString $passwd -AsPlainText -Force
    $Credential = New-Object System.Management.Automation.PSCredential($user,$password)
    try{
        $session = IsConnectionned sftp
        Get-SFTPFile -SFTPSession $session -RemoteFile $remotePath -LocalPath $localPath -Overwrite
    }
    catch{
        if(($error[0] -match "not a regular file") -or ($error[0] -match "path is not a file")){
            $ws = New-Object -ComObject WScript.Shell
            $flag=$ws.Popup("远程地址是一个目录,请确认是否下载","10","请您选择",1)
            if($flag -eq 1){
                Get-SCPFolder -ComputerName $computer -Credential $Credential -LocalFolder $localPath -RemoteFolder $remotePath -AcceptKey -Verbose
            }
        }
        else{
            Write-Error $error[0]
        }
    }
}






运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-306935-1-1.html 上篇帖子: Powershell 之多线程监控网页状态 下篇帖子: Powershell 之加解密 服务器 Linux
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表