KVM
qemu-img create -f qed ubuntu-base.qed 100G
kvm -cdrom ubuntu-14.10-desktop-amd64.iso -m 2048 ubuntu-base.qed
qemu-img create -f qed -b ubuntu-base.qed ubuntu-d-1.qed 100G &
背景執行
&
ctrl+z
bg 1
fg 1
virsh list
virsh dumpxml
virsh define
virsh start
virsh destroy
載入
virsh save ubuntu-1 ubuntu-1-backup.state
靜態存檔
apt-get install vncviewer
VNC
vncviewer 127.0.0.1:5900
9BDRN-HMGRP-FKMDF-6BWG2-76DGY
44JKhXKfTXuDXZ3NpnMBebXrfDCe6URCVjUcjxNBu1vTMzG5Yso8Jp5bAcTeQmmECLGBzP234zNLVWx996C6yMH49tSXxLw
>-------------------------------------------------------------------------<
SQL
mysql -u root -p test
-p database
SELECT * FROM
select from tablename where conclitional
select sum<ae> from student;
總和
select avg<ae> from student;
平均
select substring<student.tel,1,3> tel-3;
student第1格只顯示前3 表格名稱代換tel-3
select * frome student where age not in <25,35,55>;
java.sql.*
javax.sql.*
JDBC套件
show processlist;
process列表
status;
系統狀況
show databases;
create database test;
drop database test;
use test;
show tables;
show table from 資料庫名稱;
show columns from 資料表名稱;
顯示資料表欄位
顯示資料表欄位設定 : describe 資料表名稱;
顯示某個資料表的索引欄位設定 : show index from 資料表名稱;
新增資料表 : create table 資料表名稱 ( 欄位名稱1 資料型態,欄位名稱2 資料型態 );
新增欄位 : alter table 資料表名稱 add 欄位名稱 資料型態;
修改資料表 : alter table 舊資料表名稱 rename 新資料表名稱;
修改欄位刪除 : alter table 資料表名稱 drop 欄位名稱
刪除資料庫 : drop database 資料庫名稱;
刪除資料表 : drop table 資料表名稱;
刪除欄位 : drop 欄位名稱;
欄位刪除 : alter table 資料表名稱 drop 欄位名稱
>-------------------------------------------------------------------------<
openvpn
step 1
vars.bat.sample
---------------------------------------------------------
---------------------------------------------------------
step 2
init-config.bat
vars.bat
clean-all.bat
build-dh.bat
build-ca.bat
---------------------------------------------------------
step 3
build-key-server.bat server
---------------------------------------------------------
step 4
build-key.bat client
---------------------------------------------------------
---------------------------------------------------------
step 5
server.ovpn
---------------------------------------------------------
port 1194
dev tun
proto tcp
server 10.8.0.0 255.255.255.0
push "redirect-gateway def1 bypass-dhcp"
push "dhcp-option DNS 8.8.8.8"
client-to-client
keepalive 10 120
persist-key
persist-tun
verb 3
<ca>
-----BEGIN CERTIFICATE-----
MIIECjCCA3OgAwIBAgIJAP+gdhdVLiMVMA0GCSqGSIb3DQEBCwUAMIG1MQswCQYD
VQQGEwJVUzELMAkGA1UECBMCQ0ExFTATBgNVBAcTDFNhbkZyYW5jaXNjbzEVMBMG
A1UEChMMRm9ydC1GdW5zdG9uMR0wGwYDVQQLExRNeU9yZ2FuaXphdGlvbmFsVW5p
dDEYMBYGA1UEAxMPRm9ydC1GdW5zdG9uIENBMQ8wDQYDVQQpEwZzZXJ2ZXIxITAf
BgkqhkiG9w0BCQEWEm1lQG15aG9zdC5teWRvbWFpbjAeFw0xNjA1MTYxNTE2NTRa
Fw0yNjA1MTQxNTE2NTRaMIG1MQswCQYDVQQGEwJVUzELMAkGA1UECBMCQ0ExFTAT
BgNVBAcTDFNhbkZyYW5jaXNjbzEVMBMGA1UEChMMRm9ydC1GdW5zdG9uMR0wGwYD
VQQLExRNeU9yZ2FuaXphdGlvbmFsVW5pdDEYMBYGA1UEAxMPRm9ydC1GdW5zdG9u
IENBMQ8wDQYDVQQpEwZzZXJ2ZXIxITAfBgkqhkiG9w0BCQEWEm1lQG15aG9zdC5t
eWRvbWFpbjCBnzANBgkqhkiG9w0BAQEFAAOBjQAwgYkCgYEAuCEqro+i7zrfUalK
Y860Fa6kGQnJWdvB/G+ulz/NJ8EZG8zNKarDKvkaMTEu/whVPUewp4NNxTfvhMjO
53zQBpx/la+S+1MsG25MA8VGJg+acUQrq3mJ7s6AwLKlgJC+Ikb0P5dXTPAZJGbY
P2IyrGc1FFfQl/I0k1E4r+bP7pUCAwEAAaOCAR4wggEaMB0GA1UdDgQWBBSYNQ/X
B94RSbQCrfcrj6l6Y0IxpzCB6gYDVR0jBIHiMIHfgBSYNQ/XB94RSbQCrfcrj6l6
Y0Ixp6GBu6SBuDCBtTELMAkGA1UEBhMCVVMxCzAJBgNVBAgTAkNBMRUwEwYDVQQH
EwxTYW5GcmFuY2lzY28xFTATBgNVBAoTDEZvcnQtRnVuc3RvbjEdMBsGA1UECxMU
TXlPcmdhbml6YXRpb25hbFVuaXQxGDAWBgNVBAMTD0ZvcnQtRnVuc3RvbiBDQTEP
MA0GA1UEKRMGc2VydmVyMSEwHwYJKoZIhvcNAQkBFhJtZUBteWhvc3QubXlkb21h
aW6CCQD/oHYXVS4jFTAMBgNVHRMEBTADAQH/MA0GCSqGSIb3DQEBCwUAA4GBAHws
EeaugL/iRDobk73l7hkP8Kgtp5K58n3wYKJDSUKCtQGIts5ooE34rlW/R+FM/pRW
/QuhWK4AX/uzfwqmXutI43FLUHGoybeKYn+Q3GFmNeqCRUFBi37F/hp7JqmyxGMf
pIebG07iD2i6IWav8KntBnAMSdWdrgT8aDfLBCOP
-----END CERTIFICATE-----
</ca>
<cert>
-----BEGIN CERTIFICATE-----
MIIEdDCCA92gAwIBAgIBATANBgkqhkiG9w0BAQsFADCBtTELMAkGA1UEBhMCVVMx
CzAJBgNVBAgTAkNBMRUwEwYDVQQHEwxTYW5GcmFuY2lzY28xFTATBgNVBAoTDEZv
cnQtRnVuc3RvbjEdMBsGA1UECxMUTXlPcmdhbml6YXRpb25hbFVuaXQxGDAWBgNV
BAMTD0ZvcnQtRnVuc3RvbiBDQTEPMA0GA1UEKRMGc2VydmVyMSEwHwYJKoZIhvcN
AQkBFhJtZUBteWhvc3QubXlkb21haW4wHhcNMTYwNTE2MTUxNzIwWhcNMjYwNTE0
MTUxNzIwWjCBrDELMAkGA1UEBhMCVVMxCzAJBgNVBAgTAkNBMRUwEwYDVQQHEwxT
YW5GcmFuY2lzY28xFTATBgNVBAoTDEZvcnQtRnVuc3RvbjEdMBsGA1UECxMUTXlP
cmdhbml6YXRpb25hbFVuaXQxDzANBgNVBAMTBnNlcnZlcjEPMA0GA1UEKRMGc2Vy
dmVyMSEwHwYJKoZIhvcNAQkBFhJtZUBteWhvc3QubXlkb21haW4wgZ8wDQYJKoZI
hvcNAQEBBQADgY0AMIGJAoGBAKaesQ4y14sOyIYdKBwpnrzwWNLdSnV0zcaFpG45
AN/0rQoXwF4xqRjYHZPHma9cY3vWf98fgp9ZDN27OmUC6ULjEkjBOuRCrM07Lkuj
hECLhiDBqXzMu3ERhtFAWx3aACR/OoDRZ0XwqRZ7uVEFstY34O6nkUBVO2e42dls
3QD9AgMBAAGjggGZMIIBlTAJBgNVHRMEAjAAMBEGCWCGSAGG+EIBAQQEAwIGQDA0
BglghkgBhvhCAQ0EJxYlRWFzeS1SU0EgR2VuZXJhdGVkIFNlcnZlciBDZXJ0aWZp
Y2F0ZTAdBgNVHQ4EFgQUVd7NpL/Q+SXWhYis1W0a+LLQR/QwgeoGA1UdIwSB4jCB
34AUmDUP1wfeEUm0Aq33K4+pemNCMaehgbukgbgwgbUxCzAJBgNVBAYTAlVTMQsw
CQYDVQQIEwJDQTEVMBMGA1UEBxMMU2FuRnJhbmNpc2NvMRUwEwYDVQQKEwxGb3J0
LUZ1bnN0b24xHTAbBgNVBAsTFE15T3JnYW5pemF0aW9uYWxVbml0MRgwFgYDVQQD
Ew9Gb3J0LUZ1bnN0b24gQ0ExDzANBgNVBCkTBnNlcnZlcjEhMB8GCSqGSIb3DQEJ
ARYSbWVAbXlob3N0Lm15ZG9tYWluggkA/6B2F1UuIxUwEwYDVR0lBAwwCgYIKwYB
BQUHAwEwCwYDVR0PBAQDAgWgMBEGA1UdEQQKMAiCBnNlcnZlcjANBgkqhkiG9w0B
AQsFAAOBgQCO9/+a96G6nHi219FfqWerBwErxpfjr4vURu0zW01wdZ8OJZBS2KSi
53tXG+xFDfvdyowqrLK/e3Mp9HDWupdH6tYnxW/+P+EFASsvvwJ8y8T9p/qFMCz5
h+0JiVHcwPHlDZ1Ha1OELIQwUHVsIJmS/FYndd7qRRQl9gQNz+Tbfg==
-----END CERTIFICATE-----
</cert>
<key>
-----BEGIN PRIVATE KEY-----
MIICdwIBADANBgkqhkiG9w0BAQEFAASCAmEwggJdAgEAAoGBAKaesQ4y14sOyIYd
KBwpnrzwWNLdSnV0zcaFpG45AN/0rQoXwF4xqRjYHZPHma9cY3vWf98fgp9ZDN27
OmUC6ULjEkjBOuRCrM07LkujhECLhiDBqXzMu3ERhtFAWx3aACR/OoDRZ0XwqRZ7
uVEFstY34O6nkUBVO2e42dls3QD9AgMBAAECgYEAoo376wBLLU2U8NMNSLyKM4bB
AagHdqQoBeBoVWijo9sP3uLhOIR2lthxsrVvCJi4Lh9MzZ/uTgwQ81owVFAMxTLp
oAOwfaJm2n636F0V8LBwOIgCwb4qXO4i0i7W9OLx14Q7NlTTrpOCfArFu04oBajI
SjDBogLjorZCjX9qawECQQDcoPWd62oqlSOt318jJPmOMKzHcF9NpOlHR0skYEP8
fs0Fb5ssrr4YFssZQEiYKtoGW+3R5kJNU2uZBc0TG9HdAkEAwVUaCZBBH5PmKhcv
fYlFWLLcEcC0HFPyDxmOzI/4+9oKsnPZuEBuxNgXhXnA2NJizTbuhlPpsnTyb3PP
3j5JoQJANjoppIL0OTsm5dl9HLo9zEESdoKcKg1aePaA9ZPjoe/YnHlt/nGEr48K
pE40iZIevGlj7q9VpIPYcmgGm6e+0QJBAKzYSM8ECTUSJVS8Jdk2QKlsPxQgFOa+
pkqZrvF0RkXkSmwA50WzVVTnXSAYGjG+5lZSJi4yF11U8OpzwAQR7AECQDbY+Aj2
IFKSMAJ5Uga8HuQy54antjhubdird+KN5HvZu+8p+QvIkrjruHmQ2WM8pSZG+nYY
pyh//RVij/8illk=
-----END PRIVATE KEY-----
</key>
<dh>
-----BEGIN DH PARAMETERS-----
MIGHAoGBAJxBWOQl17MeUWlHjeAoMD/FLw9qGx1wTRYef+XIKnSUZ88ROXjde9jh
hMKq1VFUlaqJO3uo8knzC//naIWKScEsbnXr91Ms1pmDbF5XEH6f/E5YPQxD59uA
nClSlS3zh6exljLhH5xi4kQUxg7307YWqMoGF75ixZmPkv7mP1q7AgEC
-----END DH PARAMETERS-----
</dh>
---------------------------------------------------------
step 6
client.ovpn
---------------------------------------------------------
client
dev tun
proto tcp
remote 8.8.8.8 1194
nobind
persist-key
persist-tun
verb 3
<ca>
-----BEGIN CERTIFICATE-----
MIIECjCCA3OgAwIBAgIJAP+gdhdVLiMVMA0GCSqGSIb3DQEBCwUAMIG1MQswCQYD
VQQGEwJVUzELMAkGA1UECBMCQ0ExFTATBgNVBAcTDFNhbkZyYW5jaXNjbzEVMBMG
A1UEChMMRm9ydC1GdW5zdG9uMR0wGwYDVQQLExRNeU9yZ2FuaXphdGlvbmFsVW5p
dDEYMBYGA1UEAxMPRm9ydC1GdW5zdG9uIENBMQ8wDQYDVQQpEwZzZXJ2ZXIxITAf
BgkqhkiG9w0BCQEWEm1lQG15aG9zdC5teWRvbWFpbjAeFw0xNjA1MTYxNTE2NTRa
Fw0yNjA1MTQxNTE2NTRaMIG1MQswCQYDVQQGEwJVUzELMAkGA1UECBMCQ0ExFTAT
BgNVBAcTDFNhbkZyYW5jaXNjbzEVMBMGA1UEChMMRm9ydC1GdW5zdG9uMR0wGwYD
VQQLExRNeU9yZ2FuaXphdGlvbmFsVW5pdDEYMBYGA1UEAxMPRm9ydC1GdW5zdG9u
IENBMQ8wDQYDVQQpEwZzZXJ2ZXIxITAfBgkqhkiG9w0BCQEWEm1lQG15aG9zdC5t
eWRvbWFpbjCBnzANBgkqhkiG9w0BAQEFAAOBjQAwgYkCgYEAuCEqro+i7zrfUalK
Y860Fa6kGQnJWdvB/G+ulz/NJ8EZG8zNKarDKvkaMTEu/whVPUewp4NNxTfvhMjO
53zQBpx/la+S+1MsG25MA8VGJg+acUQrq3mJ7s6AwLKlgJC+Ikb0P5dXTPAZJGbY
P2IyrGc1FFfQl/I0k1E4r+bP7pUCAwEAAaOCAR4wggEaMB0GA1UdDgQWBBSYNQ/X
B94RSbQCrfcrj6l6Y0IxpzCB6gYDVR0jBIHiMIHfgBSYNQ/XB94RSbQCrfcrj6l6
Y0Ixp6GBu6SBuDCBtTELMAkGA1UEBhMCVVMxCzAJBgNVBAgTAkNBMRUwEwYDVQQH
EwxTYW5GcmFuY2lzY28xFTATBgNVBAoTDEZvcnQtRnVuc3RvbjEdMBsGA1UECxMU
TXlPcmdhbml6YXRpb25hbFVuaXQxGDAWBgNVBAMTD0ZvcnQtRnVuc3RvbiBDQTEP
MA0GA1UEKRMGc2VydmVyMSEwHwYJKoZIhvcNAQkBFhJtZUBteWhvc3QubXlkb21h
aW6CCQD/oHYXVS4jFTAMBgNVHRMEBTADAQH/MA0GCSqGSIb3DQEBCwUAA4GBAHws
EeaugL/iRDobk73l7hkP8Kgtp5K58n3wYKJDSUKCtQGIts5ooE34rlW/R+FM/pRW
/QuhWK4AX/uzfwqmXutI43FLUHGoybeKYn+Q3GFmNeqCRUFBi37F/hp7JqmyxGMf
pIebG07iD2i6IWav8KntBnAMSdWdrgT8aDfLBCOP
-----END CERTIFICATE-----
</ca>
<cert>
-----BEGIN CERTIFICATE-----
MIIEWjCCA8OgAwIBAgIBAjANBgkqhkiG9w0BAQsFADCBtTELMAkGA1UEBhMCVVMx
CzAJBgNVBAgTAkNBMRUwEwYDVQQHEwxTYW5GcmFuY2lzY28xFTATBgNVBAoTDEZv
cnQtRnVuc3RvbjEdMBsGA1UECxMUTXlPcmdhbml6YXRpb25hbFVuaXQxGDAWBgNV
BAMTD0ZvcnQtRnVuc3RvbiBDQTEPMA0GA1UEKRMGc2VydmVyMSEwHwYJKoZIhvcN
AQkBFhJtZUBteWhvc3QubXlkb21haW4wHhcNMTYwNTE2MTUxNzUyWhcNMjYwNTE0
MTUxNzUyWjCBrDELMAkGA1UEBhMCVVMxCzAJBgNVBAgTAkNBMRUwEwYDVQQHEwxT
YW5GcmFuY2lzY28xFTATBgNVBAoTDEZvcnQtRnVuc3RvbjEdMBsGA1UECxMUTXlP
cmdhbml6YXRpb25hbFVuaXQxDzANBgNVBAMTBmNsaWVudDEPMA0GA1UEKRMGc2Vy
dmVyMSEwHwYJKoZIhvcNAQkBFhJtZUBteWhvc3QubXlkb21haW4wgZ8wDQYJKoZI
hvcNAQEBBQADgY0AMIGJAoGBALxptjZheLvMoPTceR4qu2k/kWCZ8DZqdp/0c300
9CqilLvJPcHhBrfON9ELZDojrJ+NAh4k7B27Hzm4hskLIjjbE+QqmjMKHoFGbSKA
2Fc7OwP7iBqQ2QaiDNaUEZC8tUrq0Ddjo6RTx2LcLd6kiO8N+RfzzEzCiZbYzfBc
SDGtAgMBAAGjggF/MIIBezAJBgNVHRMEAjAAMC0GCWCGSAGG+EIBDQQgFh5FYXN5
LVJTQSBHZW5lcmF0ZWQgQ2VydGlmaWNhdGUwHQYDVR0OBBYEFL6IqbPz5La4Yb2k
DNEKaM/jevTpMIHqBgNVHSMEgeIwgd+AFJg1D9cH3hFJtAKt9yuPqXpjQjGnoYG7
pIG4MIG1MQswCQYDVQQGEwJVUzELMAkGA1UECBMCQ0ExFTATBgNVBAcTDFNhbkZy
YW5jaXNjbzEVMBMGA1UEChMMRm9ydC1GdW5zdG9uMR0wGwYDVQQLExRNeU9yZ2Fu
aXphdGlvbmFsVW5pdDEYMBYGA1UEAxMPRm9ydC1GdW5zdG9uIENBMQ8wDQYDVQQp
EwZzZXJ2ZXIxITAfBgkqhkiG9w0BCQEWEm1lQG15aG9zdC5teWRvbWFpboIJAP+g
dhdVLiMVMBMGA1UdJQQMMAoGCCsGAQUFBwMCMAsGA1UdDwQEAwIHgDARBgNVHREE
CjAIggZjbGllbnQwDQYJKoZIhvcNAQELBQADgYEAM3AULkp6XFRN9yyt/io0etPW
woymXACoIvWIzRLaUQ+ffhZ0QUmJhHVxBLDlEofSpuzHAb4Ad6uyJQGuzdlxsQc5
okFTI2VB5CjaqMvCDQGdrmuig9SPNmCEhtcOHQxiD2B7v+Ah63mPNG8J0SFB3ODW
9jVgj7ddDt8w2r0HNxA=
-----END CERTIFICATE-----
</cert>
<key>
-----BEGIN PRIVATE KEY-----
MIICdwIBADANBgkqhkiG9w0BAQEFAASCAmEwggJdAgEAAoGBALxptjZheLvMoPTc
eR4qu2k/kWCZ8DZqdp/0c3009CqilLvJPcHhBrfON9ELZDojrJ+NAh4k7B27Hzm4
hskLIjjbE+QqmjMKHoFGbSKA2Fc7OwP7iBqQ2QaiDNaUEZC8tUrq0Ddjo6RTx2Lc
Ld6kiO8N+RfzzEzCiZbYzfBcSDGtAgMBAAECgYEAnq49WsFuqGPnrzG8A+8jVbnG
21/qkjnJ3F9JoMqnVP0GXL1Y+N9nBAh2s+VvLRP8f4eHoBGilkuROdCyG8H3uA6/
iv44DV5v9vlPgI1RMDiDN9vgdHgM2M6GZmPjUY9TLw0G5dDRy5vClyCvaYzXj36Y
DNkxZ7ROGfzY3tKLAwECQQDdgSWTp4LtCzWiPObpl4Aq1oIrx/KApe3b8nrnOiT5
6rMkCSjnhw93jz9Kr8ZWqBj6WhNPKw99OAY1NI5p/xbBAkEA2cFIzmCzc2OOUBMB
DK/DLo+5ImU+VBYFbAVTIDTSKZ1YsVObDsUsqtdVQBnEXzg4nMWdRvizU2HaR0dF
bMFh7QJBAL5FeenkMus8fc3nUtPFeCtUKG1DTGSGJFSTbk/B+pFTsp5539FCi17A
hjW52D4IF6y2Q2/2JVADGBIMG2mh3gECQHB9qV70FcBGbf5v0tr68ZncJYffRZOq
zKJBHfBFWUymPGtfBXtb4PdgxmmW5htKr/RNIjLHx9wLcPfhmbvVKwECQFdoYe6g
rKxgLV7jVKABRYgl+LgxMfWc6JRXtk4Eu/okB4Clx8c+HspUh20QrsEJNv/Wc5+D
x58qRzDUjfghLg4=
-----END PRIVATE KEY-----
</key>
---------------------------------------------------------
---------------------------------------------------------
ufw enable
ufw default deny
ufw allow 1194/tcp
ufw allow 1194/udp
vi /etc/default/ufw
-
DEFAULT_FORWARD_POLICY="ACCEPT"
--
vi /etc/ufw/sysctl.conf
-
net/ipv4/ip_forward=1
--
sysctl -p
ufw disable
ufw enable
ufw status
service openvpn restart
iptables -t nat -A POSTROUTING -s 10.8.0.0/24 -o ppp0 -j MASQUERADE
iptables --table nat --list
>-------------------------------------------------------------------------<
redhat
#init 3
多人文字
#init 5
GUI
#init 6
reboot
#timedatectl set-local-rtc 1
硬體時鐘設置為本地時區
#systemctl set-default multi-user.target
#systemctl set-default graphical.target
change runlevel
#gsettings set org.gnome.settings-daemon.plugins.power button-power shutdown
systemctl stop firewalld.service
systemctl disable firewalld.service
blank: does nothing
suspend: makes your system suspend
shutdown: starts a normal issued shutdown procedure
hibernate: hibernates your system
nothing: does nothing
logout: log your user out
>-------------------------------------------------------------------------<
ipmitool
ipmitool -H 192.168.1.1 -U admin -P admin power status
ipmitool -H 192.168.1.1 -U admin -P admin lan print
ipmitool -H 192.168.1.1 -U admin -P admin sensor list
ipmitool -H 192.168.1.1 -U admin -P admin user list
ipmitool -H 192.168.1.1 -U admin -P admin bmc reset cold
ipmitool sel time get
BMC的時間
ipmitool sel time set "mm/dd/yyyy hh:mm:ss"
設時間
ipmitool power status
查看目前的電源狀況
ipmitool power on
開機
ipmitool power off
關機,是暴力關電,所以OS不是正常結束
ipmitool power reset
如同按下reset
ipmitool power cycle
似乎是讓系統先shutdown之後,過一秒再power on,這樣就不必常跑機房了
ipmitool power soft
透過ACPI讓OS shutdown或restart或log off
ipmitool chassis status
system status包含電源訊息,system狀況
ipmitool chassis identify
可以在機房機架中找到主機,燈號會閃15秒
ipmitool chassis restart_cause
查看上次系統重啟的原因
ipmitool -H 192.168.114.239 -U admin -P admin mc guid
ipmitool -H 192.168.114.239 -U admin -P admin raw 0x06 0x08
BMC-IPMI-mc_Device GUID
$ ipmitool -U username -P password -H 192.168.1.5 chassis power on
$ ipmitool -U username -P password -H 192.168.1.5 chassis power off
$ ipmitool -U username -P password -H 192.168.1.5 chassis power cycle
$ ipmitool -U username -P password -H 192.168.1.5 chassis power soft
$ ipmitool -U username -P password -H 192.168.1.5 chassis power status
$ ipmitool -U username -P password -H 192.168.1.5 chassis bootdev pxe
$ ipmitool -U username -P password -H 192.168.1.5 chassis bootdev bios
$ ipmitool -U username -P password -H 192.168.1.5 chassis bootdev disk
$ ipmitool -U username -P password -H 192.168.1.5 bmc info
$ ipmitool -U username -P password -H 192.168.1.5 lan print
$ ipmitool -U username -P password -H 192.168.1.5 lan set 1 ipsrc static
$ ipmitool -U username -P password -H 192.168.1.5 lan set 1 ipaddr 192.168.1.5
$ ipmitool -U username -P password -H 192.168.1.5 lan set 1 netmask 255.255.255.0
$ ipmitool -U username -P password -H 192.168.1.5 lan set 1 defgw ipaddr 192.168.1.254
$ ipmitool -U username -P password -H 192.168.1.5 mc info
$ ipmitool -U username -P password -H 192.168.1.5 mc reset cold
$ ipmitool -U username -P password -H 192.168.1.5 sdr
$ ipmitool -U username -P password -H 192.168.1.5 sel list
1. ipmitool -I lanplus -H <host> -U admin -P admin user set name 5 bob
2. ipmitool -I lanplus -H <host> -U admin -P admin user set password 5 bad_pass
3. ipmitool -I lanplus -H <host> -U admin -P admin user enable 5
4. ipmitool -I lanplus -H <host> -U admin -P admin channel setaccess 1 5 ipmi=on privilege=4
5. ipmitool -I lanplus -H <host> -U bob -P bad_pass user list 1
FB專用BMC AC斷電 ipmitool raw 0x06 0x52 0x0f 0x22 0x00 0xd9
>-------------------------------------------------------------------------<
power cycle
dmesg -C
echo "" > /var/log/messages
ipmitool sel clear
rm -rf /root/QuickHWCheck
./RunMe.sh
timedatectl set-local-rtc 1
systemctl set-default multi-user.target
gsettings set org.gnome.settings-daemon.plugins.power button-power shutdown
>-------------------------------------------------------------------------<
ESXI
Disable firewall
#esxcli network firewall get
#esxcli entwork firewall set --enabled false
Install Driver
There two types of ESXi driver
– vib
– offline_bundle
The related command
– Driver list
#esxcli software vib list
– Driver install
#esxcli software vib install –v /vib_stored_full_path.vib
#esxcli software vib install –d /offline_bundle_full_path.zip
– Drvier unistall
#esxcli software vib remove –n driver_name
OS event check(using msg_check)
Download message check tool from VRC
sit_tools>linux>utility>message-check
Download VMW white list from VRC
sit_tools>virtualization>utility>message-check
OOB command
#./msg_check.sh -2 -h esxi_ip -w white_list.csv -vmw
If have error message, please get VM-support log from ESXi
1. Open any web browser (eg: Firefox)
2. Enter URL as below https://your_ESXi_IP/cgi-bin/vm-support.cgi
3. save this log to below path \\ccbu01\cc-share\Public_Zone\VMware_log
TM02L-8YH5M-L8P81-0M2R2-80U04
JH43M-FUJ53-68Y80-0C0HK-3XEMN
>-------------------------------------------------------------------------<
bash
http://linuxdiary.blogspot.tw/2007/10/blog-post_30.html
參數
a && b
a || b
a && b || c
因為 a 為假時,a && b 為假,所以會去執行 c。
a && b && c && d && e && f || g
中括號的條件判斷
使用中括號必須要特別注意,因為中括號用在很多地方,包括萬用字元與正規表示法等等,所以如果要在 bash 的語法當中使用中括號作為 shell 的判斷式時,必須要注意中括號的兩端需要有空白字元來分隔喔!
檔案判斷
參數
-r file
-w file
-x file
-f file
-d file
-c file
-b file
-s file
-t file
-p file
-h file
-L file
字串比較
參數
"字串" = "字串"
"字串" == "字串"
"字串" != "字串"
-z "字串"
-n "字串"
數字比較
參數
-eq
-ne
-gt
-ge
-lt
-le
多重條件比較
參數
-a
-o
!
>-------------------------------------------------------------------------<
raspberry pi
raspi-config
expand_rootfs
/etc/sysctl.conf
net.ipv6.conf.all.disable_ipv6 = 1
sudo sysctl -p
sudo ifconfig eth0 down && sudo ifconfig eth0 up
ip link set eth0 down
/etc/ssh/sshd_config
#PermitRootLogin without-password
PermitRootLogin yes
apt-get install --no-install-recommends ubuntu-desktop
>-------------------------------------------------------------------------<
bash多開ping
#!/bin/bash
if [ $# -eq 0 ]
then
echo 'need input "ip_list" file'
exit 1
fi
echo Please Check The IP List:
cat $1 | tr -s "\n" > ip_l
cat ip_l > $1
rm ./ip_l
cat $1 | tr -s "\n" | nl
read -r -p "continue? (y/n)" key
if [ "$key" = 'y' ]; then
echo "Start to Run"
else
echo "bye"
exit 1
fi
for i in
echo
gnome-terminal -x ping
done
>-------------------------------------------------------------------------<
ubuntu NAT
iptables -A FORWARD -o ens160 -j ACCEPT
iptables -A FORWARD -m state --state ESTABLISHED,RELATED -i ens160 -j ACCEPT
iptables -t nat -A POSTROUTING -o ens160 -j MASQUERADE
route add default gw <gatway ip> eth1
>-------------------------------------------------------------------------<
iperf
ip addr add 10.10.0.1/24 dev eth0
ip addr add 10.10.1.1/24 dev eth1
ip addr add 10.10.2.1/24 dev eth2
ip addr add 10.10.3.1/24 dev eth3
ip link set eth0 up
ip link set eth1 up
ip link set eth2 up
ip link set eth3 up
iperf -s -p 2000 -D
iperf -s -p 2001 -D
iperf -s -p 2002 -D
iperf -s -p 2003 -D
iperf -c 10.10.0.2 -l 64k -w 64k -i 5 -P 10 -p 2000 -t 20 > eth0.txt
iperf -c 10.10.1.2 -l 64k -w 64k -i 5 -P 10 -p 2000 -t 20 > eth1.txt
iperf -c 10.10.2.2 -l 64k -w 64k -i 5 -P 10 -p 2000 -t 20 > eth2.txt
iperf -c 10.10.3.2 -l 64k -w 64k -i 5 -P 10 -p 2000 -t 20 > eth3.txt
ip addr add 10.10.0.2/24 dev eth0
ip addr add 10.10.1.2/24 dev eth1
ip addr add 10.10.2.2/24 dev eth2
ip addr add 10.10.3.2/24 dev eth3
ip link set eth0 up
ip link set eth1 up
ip link set eth2 up
ip link set eth3 up
iperf -s -p 2000 -D
iperf -s -p 2001 -D
iperf -s -p 2002 -D
iperf -s -p 2003 -D
iperf -c 10.10.0.1 -l 64k -w 64k -i 5 -P 10 -p 2000 -t 20 > eth0.txt
iperf -c 10.10.1.1 -l 64k -w 64k -i 5 -P 10 -p 2000 -t 20 > eth1.txt
iperf -c 10.10.2.1 -l 64k -w 64k -i 5 -P 10 -p 2000 -t 20 > eth2.txt
iperf -c 10.10.3.1 -l 64k -w 64k -i 5 -P 10 -p 2000 -t 20 > eth3.txt
ip addr del 10.10.0.2/24 dev eth0
>-------------------------------------------------------------------------<
vmkfstools
vmkfstools -i ./win2016-clean_0-000002.vmdk ./win2016-01.vmdk
>-------------------------------------------------------------------------<
Mellanox driver
Linux SW/Drivers
http://www.mellanox.com/page/products_dyn?product_family=26&mtag=linux_sw_drivers
./mlnxofedinstall
Mellanox Firmware Tools (MFT)
http://www.mellanox.com/page/management_tools
mst start
Mellanox UEFI
http://www.mellanox.com/page/products_dyn?product_family=257&mtag=UEFI
flint -d /dev/mst/mt4117_pciconf0 --allow_rom_change brom ./FlexBoot-RELEASE_0x1015.efirom
flint -d /dev/mst/mt4117_pciconf0 q
http://www.mellanox.com/related-docs/prod_software/Mellanox_PreBoot_Drivers_User_Manual_v2.9.pdf
mlxup
./mlxup -d -i -f
http://www.mellanox.com/page/mlxup_firmware_tool
http://www.mellanox.com/page/firmware_table_ConnectX4LxEN
mst start
mst status
flint -d /dev/mst/mt4117_pciconf0 -i ./fw-ConnectX4Lx-rel-14_20_1010-MCX4411A-ACQ_Ax-FlexBoot-3.5.210.bin --allow_psid_change burn
reboot
flint -d /dev/mst/mt4117_pciconf0 --allow_rom_change brom ./FlexBoot-RELEASE_0x1015.efirom
http://www.mellanox.com/page/firmware_download
>-------------------------------------------------------------------------<
freeradius
apt install freeradius
client ipv6 {
ipv6addr = 2017::/16
secret = 123456
}
client ipv4 {
ipaddr = 192.168.0.0/16
secret = 123456
}
radius_h4 Cleartext-Password := "123456"
Attr-26=0x483D34
radius_h3 Cleartext-Password := "123456"
Attr-26=0x483D33
radius_h2 Cleartext-Password := "123456"
Attr-26=0x483D32
radius_h1 Cleartext-Password := "123456"
Attr-26=0x483D31
radius_h0 Cleartext-Password := "123456"
Attr-26=0x483D30
suttest Cleartext-Password := "Adtest123"
Attr-26=0x483D34
usertest Cleartext-Password := "Password12"
Attr-26=0x483D34
radius_admin: Password: "123456"
Vendor-Specific Attributes: "H=4, I=4"
radius_operator: Password: "654321"
Vendor-Specific Attributes: "H=3, I=3"
radius_user: Password: "654321"
Vendor-Specific Attributes: "H=2, I=2"
radius_callback: Password: "654321"
Vendor-Specific Attributes: "H=1, I=1"
https://www.supermicro.com/support/faqs/faq.cfm?faq=22374
On pages 9 and 10 it gives the following example:
"radius_admin" User-Password == "123456"
Vendor-Specific = "H=4, I=4"
In FreeRadius 2.1.12, it should be:
"radius_admin" Cleartext-Password := "123456"
Vendor-Specific = "H=4, I=4"
HOWEVER, the "Vendor-specific" attribute is no longer supported by the RFC, which is why I was unable to get it to work in FreeRadius 3.0.4.
In FreeRadius >= 3.0.4 it should be:
"radius_admin" Cleartext-Password := "123456"
Attr-26 = 0x483D342C20493D34
(where the 0xblahblah) is the hex-encoding of the "H=4, I=4" string.
others are here:
Callback H=1, I=1 Attr-26 = 0x483D312C20493D31
User H=2, I=2 Attr-26 = 0x483D322C20493D32
Operator H=3, I=3 Attr-26 = 0x483D332C20493D33
Administrator H=4, I=4 Attr-26 = 0x483D342C20493D34
>-------------------------------------------------------------------------<
grub.cfg
set http_prefix="(http,192.168.1.1)"
set default='Reboot'
set timeout=60
if [ $grub_platform == efi ] ;then
set platform="UEFI"
insmod efi_gop
insmod efi_uga
insmod font
else
set platform="BIOS"
fi
menuentry "Exit (BOOT MODE: ${platform} $grub_platform $grub_cpu)" --unrestricted {
exit
}
menuentry "Reboot" --unrestricted {
reboot
}
menuentry 'Ubuntu Server 17.10' {
linux ${http_prefix}/linux
initrd ${http_prefix}/initrd.gz
}
>-------------------------------------------------------------------------<
pxe
option domain-name "sitddns.com";
option domain-name-servers 192.168.16.1;
default-lease-time 600;
max-lease-time 7200;
ddns-update-style interim;
update-static-leases on;
zone sitddns.com. {
primary 192.168.16.1;
}
option space PXE;
option PXE.mtftp-ip code 1 = ip-address;
option PXE.mtftp-cport code 2 = unsigned integer 16;
option PXE.mtftp-sport code 3 = unsigned integer 16;
option PXE.mtftp-tmout code 4 = unsigned integer 8;
option PXE.mtftp-delay code 5 = unsigned integer 8;
option arch code 93 = unsigned integer 16; # RFC4578
subnet 192.168.16.0 netmask 255.255.255.0 {
range 192.168.16.50 192.168.16.100;
option routers 192.168.16.1;
class "pxeclients" {
}
}
>-------------------------------------------------------------------------<
Switch port mirror
將0/1的封包導到0/2做monitor
# configure
# port-monitor session 1 source interface 0/1
# port-monitor session 1 destination interface 0/2
enable port-monitor
# port-monitor session 1 mode
check port-monitor status
# do show port-monitor session
disable port-monitor
# no port-monitor session 1 mode
>-------------------------------------------------------------------------<
bash loop
#!/bin/bash
echo "" > running.log
ifconfig > g_ifconfig.txt
main(){
while [:]
do
for j in
do
done
ifconfig > now_ifconfig.txt
diff now_ifconfig.txt g_ifconfig.txt
if [ $? -ne 0 ]; then
else
fi
done
}
main 2>&1 | tee -a "running.log"
>-------------------------------------------------------------------------<
robot
CheckAllSensors
${req_dict} Create Dictionary
: FOR ${INDEX} IN RANGE 1 89
\ Log ${INDEX}
\ Click Element xpath=//*[@id="_infoLeft"]/div/table/tbody/tr[${INDEX}]/td[1]
\ Element Text Should Be xpath=//*[@id="_infoLeft"]/div/table/tbody/tr[${INDEX}]/td[1] @{Sensor_List}[${INDEX - 1}]
\ Element Text Should Be xpath=//*[@id="_infoLeft"]/div/table/tbody/tr[${INDEX}]/td[2] @{Sensor_Status}[${INDEX - 1}]
\ ${temp}= Get Text xpath=//*[@id="_lowerC"]
\ Set To Dictionary ${req_dict} @{Sensor_List}[${INDEX - 1}]_lc=${temp}
\ ${temp}= Get Text xpath=//*[@id="_lowerNC"]
\ Set To Dictionary ${req_dict} @{Sensor_List}[${INDEX - 1}]_lnc=${temp}
\ ${temp}= Get Text xpath=//*[@id="_upperC"]
\ Set To Dictionary ${req_dict} @{Sensor_List}[${INDEX - 1}]_uc=${temp}
\ ${temp}= Get Text xpath=//*[@id="_upperNC"]
\ Set To Dictionary ${req_dict} @{Sensor_List}[${INDEX - 1}]_unc=${temp}
Log ${req_dict}
*** Settings ***
Suite Teardown Close All Browsers
Force Tags RM17_Sanity
Resource ../Config_COMMON/VAR_User.robot
Resource ../Config_IPMI/KEY_Common.robot
Resource ../Config_WEB/KEY_Common.robot
Library String
Library json
Library Collections
Library OperatingSystem
Library Selenium2Library
*** Variables ***
@{Sensor_List} HDD0 HDD1 HDD2 HDD3 HDD4 HDD5 HDD6
... HDD7 HDD8 HDD9 HDD10 HDD11 HDD12 HDD13
... HDD14 HDD15 HDD16 HDD17 HDD18 HDD19 HDD20
... HDD21 HDD22 HDD23 Temp_Outlet Service_Status CPU_0 CPU_1
... Temp_CPU0 Temp_CPU1 Temp_DIMM_AB Temp_DIMM_CD Temp_DIMM_EF Temp_DIMM_GH Temp_VR_CPU0
... Temp_VR_CPU1 Temp_VR_DIMM_AB Temp_VR_DIMM_CD Temp_VR_DIMM_EF Temp_VR_DIMM_GH CPU_DIMM_VRHOT DIMM_HOT
... Temp_PCI_Area Temp_PCH Fan_SYS0 Fan_SYS1 Fan_SYS2 Fan_SYS3 Fan_SYS4
... Fan_SYS5 Fan_SYS6 Fan_SYS7 Volt_P3V3 Volt_P5V Volt_P12V Volt_P1V05
... Volt_P1V8_AUX Volt_P3V3_AUX Volt_P5V_AUX Volt_P3V_BAT SYS_NIC1_LinkUp SYS_NIC2_LinkUp Volt_VR_CPU0
... Volt_VR_CPU1 Volt_VR_DIMM_AB Volt_VR_DIMM_CD Volt_VR_DIMM_EF Volt_VR_DIMM_GH PSU1 Status PSU2 Status
... PSU1 Input PSU2 Input PSU Redundancy Event Log Watchdog Power Unit System Event
... BMC_Mem_Free CATERR Temp_PCI_Inlet1 Temp_PCI_Inlet2 Temp_Ambient_FP Button Airflow
... NVMeSSD_0 NVMeSSD_1 Fan_SSD0 Fan_SSD1
@{Sensor_Status} Drive Presence Drive Presence Drive Presence Drive Presence Drive Presence Drive Presence Drive Presence
... Drive Presence Drive Presence Drive Presence Drive Presence Drive Presence Drive Presence Drive Presence
... Drive Presence Drive Presence Drive Presence Drive Presence Drive Presence Drive Presence Drive Presence
... Drive Presence Drive Presence Drive Presence Normal KVM service is running Virtual storage service is running Web service is running Processor Presence Detected Processor Presence Detected
... Normal Normal Normal Normal Normal Normal Normal
... Normal Normal Normal Normal Normal All deasserted All deasserted
... Normal Normal Normal Normal Normal Normal Normal
... Normal Normal Normal Normal Normal Normal Normal
... Normal Normal Normal Normal State Asserted All deasserted Normal
... Normal Normal Normal Normal Normal Presence Detected Presence Detected
... Normal Normal Fully Redundant (Redundancy Regained) Log Area Reset/Cleared All deasserted All deasserted All deasserted
... Normal All deasserted Normal Normal Normal All deasserted Normal
... Normal Normal Normal Normal
&{Sensor_Spec} HDD0_lc=N/A HDD0_lnc=N/A HDD0_uc=N/A HDD0_unc=N/A HDD1_lc=N/A HDD1_lnc=N/A HDD1_uc=N/A
... HDD1_unc=N/A HDD2_lc=N/A HDD2_lnc=N/A HDD2_uc=N/A HDD2_unc=N/A HDD3_lc=N/A HDD3_lnc=N/A
... HDD3_uc=N/A HDD3_unc=N/A HDD4_lc=N/A HDD4_lnc=N/A HDD4_uc=N/A HDD4_unc=N/A HDD5_lc=N/A
... HDD5_lnc=N/A HDD5_uc=N/A HDD5_unc=N/A HDD6_lc=N/A HDD6_lnc=N/A HDD6_uc=N/A HDD6_unc=N/A
... HDD7_lc=N/A HDD7_lnc=N/A HDD7_uc=N/A HDD7_unc=N/A HDD8_lc=N/A HDD8_lnc=N/A HDD8_uc=N/A
... HDD8_unc=N/A HDD9_lc=N/A HDD9_lnc=N/A HDD9_uc=N/A HDD9_unc=N/A HDD10_lc=N/A HDD10_lnc=N/A
... HDD10_uc=N/A HDD10_unc=N/A HDD11_lc=N/A HDD11_lnc=N/A HDD11_uc=N/A HDD11_unc=N/A HDD12_lc=N/A
... HDD12_lnc=N/A HDD12_uc=N/A HDD12_unc=N/A HDD13_lc=N/A HDD13_lnc=N/A HDD13_uc=N/A HDD13_unc=N/A
... HDD14_lc=N/A HDD14_lnc=N/A HDD14_uc=N/A HDD14_unc=N/A HDD15_lc=N/A HDD15_lnc=N/A HDD15_uc=N/A
... HDD15_unc=N/A HDD16_lc=N/A HDD16_lnc=N/A HDD16_uc=N/A HDD16_unc=N/A HDD17_lc=N/A HDD17_lnc=N/A
... HDD17_uc=N/A HDD17_unc=N/A HDD18_lc=N/A HDD18_lnc=N/A HDD18_uc=N/A HDD18_unc=N/A HDD19_lc=N/A
... HDD19_lnc=N/A HDD19_uc=N/A HDD19_unc=N/A HDD20_lc=N/A HDD20_lnc=N/A HDD20_uc=N/A HDD20_unc=N/A
... HDD21_lc=N/A HDD21_lnc=N/A HDD21_uc=N/A HDD21_unc=N/A HDD22_lc=N/A HDD22_lnc=N/A HDD22_uc=N/A
... HDD22_unc=N/A HDD23_lc=N/A HDD23_lnc=N/A HDD23_uc=N/A HDD23_unc=N/A Temp_Outlet_lc=N/A Temp_Outlet_lnc=N/A
... Temp_Outlet_uc=N/A Temp_Outlet_unc=N/A Service_Status_lc=N/A Service_Status_lnc=N/A Service_Status_uc=N/A Service_Status_unc=N/A CPU_0_lc=N/A
... CPU_0_lnc=N/A CPU_0_uc=N/A CPU_0_unc=N/A CPU_1_lc=N/A CPU_1_lnc=N/A CPU_1_uc=N/A CPU_1_unc=N/A
... Temp_CPU0_lc=N/A Temp_CPU0_lnc=N/A Temp_CPU0_uc=100 \u00b0 C Temp_CPU0_unc=99 \u00b0 C Temp_CPU1_lc=N/A Temp_CPU1_lnc=N/A Temp_CPU1_uc=100 \u00b0 C
... Temp_CPU1_unc=99 \u00b0 C Temp_DIMM_AB_lc=N/A Temp_DIMM_AB_lnc=N/A Temp_DIMM_AB_uc=100 \u00b0 C Temp_DIMM_AB_unc=99 \u00b0 C Temp_DIMM_CD_lc=N/A Temp_DIMM_CD_lnc=N/A
... Temp_DIMM_CD_uc=85 \u00b0 C Temp_DIMM_CD_unc=84 \u00b0 C Temp_DIMM_EF_lc=N/A Temp_DIMM_EF_lnc=N/A Temp_DIMM_EF_uc=85 \u00b0 C Temp_DIMM_EF_unc=84 \u00b0 C Temp_DIMM_GH_lc=N/A
... Temp_DIMM_GH_lnc=N/A Temp_DIMM_GH_uc=85 \u00b0 C Temp_DIMM_GH_unc=84 \u00b0 C Temp_VR_CPU0_lc=N/A Temp_VR_CPU0_lnc=N/A Temp_VR_CPU0_uc=85 \u00b0 C Temp_VR_CPU0_unc=84 \u00b0 C
... Temp_VR_CPU1_lc=N/A Temp_VR_CPU1_lnc=N/A Temp_VR_CPU1_uc=105 \u00b0 C Temp_VR_CPU1_unc=104 \u00b0 C Temp_VR_DIMM_AB_lc=N/A Temp_VR_DIMM_AB_lnc=N/A Temp_VR_DIMM_AB_uc=105 \u00b0 C
... Temp_VR_DIMM_AB_unc=104 \u00b0 C Temp_VR_DIMM_CD_lc=N/A Temp_VR_DIMM_CD_lnc=N/A Temp_VR_DIMM_CD_uc=105 \u00b0 C Temp_VR_DIMM_CD_unc=104 \u00b0 C Temp_VR_DIMM_EF_lc=N/A Temp_VR_DIMM_EF_lnc=N/A
... Temp_VR_DIMM_EF_uc=105 \u00b0 C Temp_VR_DIMM_EF_unc=104 \u00b0 C Temp_VR_DIMM_GH_lc=N/A Temp_VR_DIMM_GH_lnc=N/A Temp_VR_DIMM_GH_uc=105 \u00b0 C Temp_VR_DIMM_GH_unc=104 \u00b0 C CPU_DIMM_VRHOT_lc=N/A
... CPU_DIMM_VRHOT_lnc=N/A CPU_DIMM_VRHOT_uc=N/A CPU_DIMM_VRHOT_unc=N/A DIMM_HOT_lc=N/A DIMM_HOT_lnc=N/A DIMM_HOT_uc=N/A DIMM_HOT_unc=N/A
... Temp_PCI_Area_lc=N/A Temp_PCI_Area_lnc=N/A Temp_PCI_Area_uc=80 \u00b0 C Temp_PCI_Area_unc=75 \u00b0 C Temp_PCH_lc=N/A Temp_PCH_lnc=N/A Temp_PCH_uc=100 \u00b0 C
... Temp_PCH_unc=98 \u00b0 C Fan_SYS0_lc=N/A Fan_SYS0_lnc=N/A Fan_SYS0_uc=100 \u00b0 C Fan_SYS0_unc=98 \u00b0 C Fan_SYS1_lc=500 RPM Fan_SYS1_lnc=1000 RPM
... Fan_SYS1_uc=N/A Fan_SYS1_unc=N/A Fan_SYS2_lc=500 RPM Fan_SYS2_lnc=1000 RPM Fan_SYS2_uc=N/A Fan_SYS2_unc=N/A Fan_SYS3_lc=500 RPM
... Fan_SYS3_lnc=1000 RPM Fan_SYS3_uc=N/A Fan_SYS3_unc=N/A Fan_SYS4_lc=500 RPM Fan_SYS4_lnc=1000 RPM Fan_SYS4_uc=N/A Fan_SYS4_unc=N/A
... Fan_SYS5_lc=500 RPM Fan_SYS5_lnc=1000 RPM Fan_SYS5_uc=N/A Fan_SYS5_unc=N/A Fan_SYS6_lc=500 RPM Fan_SYS6_lnc=1000 RPM Fan_SYS6_uc=N/A
... Fan_SYS6_unc=N/A Fan_SYS7_lc=500 RPM Fan_SYS7_lnc=1000 RPM Fan_SYS7_uc=N/A Fan_SYS7_unc=N/A Volt_P3V3_lc=3.132 Volts Volt_P3V3_lnc=N/A
... Volt_P3V3_uc=3.466 Volts Volt_P3V3_unc=N/A Volt_P5V_lc=4.743 Volts Volt_P5V_lnc=N/A Volt_P5V_uc=5.251 Volts Volt_P5V_unc=N/A Volt_P12V_lc=4.743 Volts
... Volt_P12V_lnc=N/A Volt_P12V_uc=5.251 Volts Volt_P12V_unc=N/A Volt_P1V05_lc=0.99 Volts Volt_P1V05_lnc=N/A Volt_P1V05_uc=1.107 Volts Volt_P1V05_unc=N/A
... Volt_P1V8_AUX_lc=0.99 Volts Volt_P1V8_AUX_lnc=N/A Volt_P1V8_AUX_uc=1.107 Volts Volt_P1V8_AUX_unc=N/A Volt_P3V3_AUX_lc=3.132 Volts Volt_P3V3_AUX_lnc=N/A Volt_P3V3_AUX_uc=3.466 Volts
... Volt_P3V3_AUX_unc=N/A Volt_P5V_AUX_lc=4.622 Volts Volt_P5V_AUX_lnc=N/A Volt_P5V_AUX_uc=5.372 Volts Volt_P5V_AUX_unc=N/A Volt_P3V_BAT_lc=4.622 Volts Volt_P3V_BAT_lnc=N/A
... Volt_P3V_BAT_uc=5.372 Volts Volt_P3V_BAT_unc=N/A SYS_NIC1_LinkUp_lc=N/A SYS_NIC1_LinkUp_lnc=N/A SYS_NIC1_LinkUp_uc=N/A SYS_NIC1_LinkUp_unc=N/A SYS_NIC2_LinkUp_lc=N/A
... SYS_NIC2_LinkUp_lnc=N/A SYS_NIC2_LinkUp_uc=N/A SYS_NIC2_LinkUp_unc=N/A Volt_VR_CPU0_lc=1.35 Volts Volt_VR_CPU0_lnc=N/A Volt_VR_CPU0_uc=1.96 Volts Volt_VR_CPU0_unc=N/A
... Volt_VR_CPU1_lc=1.35 Volts Volt_VR_CPU1_lnc=N/A Volt_VR_CPU1_uc=1.96 Volts Volt_VR_CPU1_unc=N/A Volt_VR_DIMM_AB_lc=1.35 Volts Volt_VR_DIMM_AB_lnc=N/A Volt_VR_DIMM_AB_uc=1.96 Volts
... Volt_VR_DIMM_AB_unc=N/A Volt_VR_DIMM_CD_lc=1.08 Volts Volt_VR_DIMM_CD_lnc=N/A Volt_VR_DIMM_CD_uc=1.32 Volts Volt_VR_DIMM_CD_unc=N/A Volt_VR_DIMM_EF_lc=1.08 Volts Volt_VR_DIMM_EF_lnc=N/A
... Volt_VR_DIMM_EF_uc=1.32 Volts Volt_VR_DIMM_EF_unc=N/A Volt_VR_DIMM_GH_lc=1.08 Volts Volt_VR_DIMM_GH_lnc=N/A Volt_VR_DIMM_GH_uc=1.32 Volts Volt_VR_DIMM_GH_unc=N/A PSU1 Status_lc=N/A
... PSU1 Status_lnc=N/A PSU1 Status_uc=N/A PSU1 Status_unc=N/A PSU2 Status_lc=N/A PSU2 Status_lnc=N/A PSU2 Status_uc=N/A PSU2 Status_unc=N/A
... PSU1 Input_lc=0 Watts PSU1 Input_lnc=N/A PSU1 Input_uc=N/A PSU1 Input_unc=N/A PSU2 Input_lc=0 Watts PSU2 Input_lnc=N/A PSU2 Input_uc=N/A
... PSU2 Input_unc=N/A PSU Redundancy_lc=N/A PSU Redundancy_lnc=N/A PSU Redundancy_uc=N/A PSU Redundancy_unc=N/A Event Log_lc=N/A Event Log_lnc=N/A
... Event Log_uc=N/A Event Log_unc=N/A Watchdog_lc=N/A Watchdog_lnc=N/A Watchdog_uc=N/A Watchdog_unc=N/A Power Unit_lc=N/A
... Power Unit_lnc=N/A Power Unit_uc=N/A Power Unit_unc=N/A System Event_lc=N/A System Event_lnc=N/A System Event_uc=N/A System Event_unc=N/A
... BMC_Mem_Free_lc=N/A BMC_Mem_Free_lnc=N/A BMC_Mem_Free_uc=N/A BMC_Mem_Free_unc=N/A CATERR_lc=N/A CATERR_lnc=N/A CATERR_uc=N/A
... CATERR_unc=N/A Temp_PCI_Inlet1_lc=N/A Temp_PCI_Inlet1_lnc=N/A Temp_PCI_Inlet1_uc=80 \u00b0 C Temp_PCI_Inlet1_unc=75 \u00b0 C Temp_PCI_Inlet2_lc=N/A Temp_PCI_Inlet2_lnc=N/A
... Temp_PCI_Inlet2_uc=80 \u00b0 C Temp_PCI_Inlet2_unc=75 \u00b0 C Temp_Ambient_FP_lc=0 \u00b0 C Temp_Ambient_FP_lnc=N/A Temp_Ambient_FP_uc=45 \u00b0 C Temp_Ambient_FP_unc=41 \u00b0 C Button_lc=0 \u00b0 C
... Button_lnc=N/A Button_uc=45 \u00b0 C Button_unc=41 \u00b0 C Airflow_lc=N/A Airflow_lnc=N/A Airflow_uc=N/A Airflow_unc=N/A
... NVMeSSD_0_lc=N/A NVMeSSD_0_lnc=N/A NVMeSSD_0_uc=74 \u00b0 C NVMeSSD_0_unc=73 \u00b0 C NVMeSSD_1_lc=N/A NVMeSSD_1_lnc=N/A NVMeSSD_1_uc=74 \u00b0 C
... NVMeSSD_1_unc=73 \u00b0 C Fan_SSD0_lc=500 RPM Fan_SSD0_lnc=1000 RPM Fan_SSD0_uc=N/A Fan_SSD0_unc=N/A Fan_SSD1_lc=500 RPM Fan_SSD1_lnc=1000 RPM
... Fan_SSD1_uc=N/A Fan_SSD1_unc=N/A
*** Test Cases ***
GetSpec
Run wget -O "S2B_S2Sx BMC FW Spec.rev047.doc" -N "http://192.168.10.147/10606121/test/raw/master/S2B_S2Sx%20BMC%20FW%20Spec.rev047.doc"
Run antiword "S2B_S2Sx BMC FW Spec.rev047.doc" > Spec.txt
${spec_temp} Run cat Spec.txt |grep Temp_DIMM_AB |sed -n '3p'|awk '{print $4 "| "}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} Temp_DIMM_AB_uc=${spec_temp} ° C
${spec_temp} Run cat Spec.txt |grep Temp_DIMM_AB |sed -n '3p'|awk '{print $3 "| "}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} Temp_DIMM_AB_unc=${spec_temp} ° C
${spec_temp} Run cat Spec.txt |grep Temp_DIMM_CD |sed -n '3p'|awk '{print $4 "| "}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} Temp_DIMM_CD_uc=${spec_temp} ° C
${spec_temp} Run cat Spec.txt |grep Temp_DIMM_CD |sed -n '3p'|awk '{print $3 "| "}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} Temp_DIMM_CD_unc=${spec_temp} ° C
${spec_temp} Run cat Spec.txt |grep Temp_DIMM_EF |sed -n '3p'|awk '{print $4 "| "}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} Temp_DIMM_EF_uc=${spec_temp} ° C
${spec_temp} Run cat Spec.txt |grep Temp_DIMM_EF |sed -n '3p'|awk '{print $3 "| "}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} Temp_DIMM_EF_unc=${spec_temp} ° C
${spec_temp} Run cat Spec.txt |grep Temp_DIMM_GH |sed -n '3p'|awk '{print $4 "| "}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} Temp_DIMM_GH_uc=${spec_temp} ° C
${spec_temp} Run cat Spec.txt |grep Temp_DIMM_GH |sed -n '3p'|awk '{print $3 "| "}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} Temp_DIMM_GH_unc=${spec_temp} ° C
${spec_temp} Run cat Spec.txt |grep Temp_VR_CPU0 |sed -n '3p'|awk '{print $4 "| "}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} Temp_VR_CPU0_uc=${spec_temp} ° C
${spec_temp} Run cat Spec.txt |grep Temp_VR_CPU0 |sed -n '3p'|awk '{print $3 "| "}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} Temp_VR_CPU0_unc=${spec_temp} ° C
${spec_temp} Run cat Spec.txt |grep Temp_VR_CPU1 |sed -n '3p'|awk '{print $4 "| "}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} Temp_VR_CPU1_uc=${spec_temp} ° C
${spec_temp} Run cat Spec.txt |grep Temp_VR_CPU1 |sed -n '3p'|awk '{print $3 "| "}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} Temp_VR_CPU1_unc=${spec_temp} ° C
${spec_temp} Run cat Spec.txt |grep Temp_VR_DIMM_AB |sed -n '3p'|awk '{print $4 "| "}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} Temp_VR_DIMM_AB_uc=${spec_temp} ° C
${spec_temp} Run cat Spec.txt |grep Temp_VR_DIMM_AB |sed -n '3p'|awk '{print $3 "| "}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} Temp_VR_DIMM_AB_unc=${spec_temp} ° C
${spec_temp} Run cat Spec.txt |grep Temp_VR_DIMM_CD |sed -n '3p'|awk '{print $4 "| "}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} Temp_VR_DIMM_CD_uc=${spec_temp} ° C
${spec_temp} Run cat Spec.txt |grep Temp_VR_DIMM_CD |sed -n '3p'|awk '{print $3 "| "}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} Temp_VR_DIMM_CD_unc=${spec_temp} ° C
${spec_temp} Run cat Spec.txt |grep Temp_VR_DIMM_EF |sed -n '3p'|awk '{print $4 "| "}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} Temp_VR_DIMM_EF_uc=${spec_temp} ° C
${spec_temp} Run cat Spec.txt |grep Temp_VR_DIMM_EF |sed -n '3p'|awk '{print $3 "| "}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} Temp_VR_DIMM_EF_unc=${spec_temp} ° C
${spec_temp} Run cat Spec.txt |grep Temp_VR_DIMM_GH |sed -n '3p'|awk '{print $4 "| "}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} Temp_VR_DIMM_GH_uc=${spec_temp} ° C
${spec_temp} Run cat Spec.txt |grep Temp_VR_DIMM_GH |sed -n '3p'|awk '{print $3 "| "}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} Temp_VR_DIMM_GH_unc=${spec_temp} ° C
${spec_temp} Run cat Spec.txt |grep Temp_PCI_Area |sed -n '2p'|awk '{print $4 "| "}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} Temp_PCI_Area_uc=${spec_temp} ° C
${spec_temp} Run cat Spec.txt |grep Temp_PCI_Area |sed -n '2p'|awk '{print $3 "| "}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} Temp_PCI_Area_unc=${spec_temp} ° C
${spec_temp} Run cat Spec.txt |grep Temp_PCH |sed -n '2p'|awk '{print $4 "| "}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} Temp_PCH_uc=${spec_temp} ° C
${spec_temp} Run cat Spec.txt |grep Temp_PCH |sed -n '2p'|awk '{print $3 "| "}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} Temp_PCH_unc=${spec_temp} ° C
${spec_temp} Run cat Spec.txt |grep Fan_SYS0 |sed -n '$p'|awk '{print $3 "|"}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} "Fan_SYS0_uc=${spec_temp} RPM
${spec_temp} Run cat Spec.txt |grep Fan_SYS0 |sed -n '$p'|awk '{print $5 "|"}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} "Fan_SYS0_unc=${spec_temp} RPM
${spec_temp} Run cat Spec.txt |grep Fan_SYS1 |sed -n '$p'|awk '{print $3 "|"}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} "Fan_SYS1_uc=${spec_temp} RPM
${spec_temp} Run cat Spec.txt |grep Fan_SYS1 |sed -n '$p'|awk '{print $5 "|"}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} "Fan_SYS1_unc=${spec_temp} RPM
${spec_temp} Run cat Spec.txt |grep Fan_SYS2 |sed -n '$p'|awk '{print $3 "|"}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} "Fan_SYS2_uc=${spec_temp} RPM
${spec_temp} Run cat Spec.txt |grep Fan_SYS2 |sed -n '$p'|awk '{print $5 "|"}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} "Fan_SYS2_unc=${spec_temp} RPM
${spec_temp} Run cat Spec.txt |grep Fan_SYS3 |sed -n '$p'|awk '{print $3 "|"}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} "Fan_SYS3_uc=${spec_temp} RPM
${spec_temp} Run cat Spec.txt |grep Fan_SYS3 |sed -n '$p'|awk '{print $5 "|"}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} "Fan_SYS3_unc=${spec_temp} RPM
${spec_temp} Run cat Spec.txt |grep Fan_SYS4 |sed -n '$p'|awk '{print $3 "|"}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} "Fan_SYS4_uc=${spec_temp} RPM
${spec_temp} Run cat Spec.txt |grep Fan_SYS4 |sed -n '$p'|awk '{print $5 "|"}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} "Fan_SYS4_unc=${spec_temp} RPM
${spec_temp} Run cat Spec.txt |grep Fan_SYS5 |sed -n '$p'|awk '{print $3 "|"}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} "Fan_SYS5_uc=${spec_temp} RPM
${spec_temp} Run cat Spec.txt |grep Fan_SYS5 |sed -n '$p'|awk '{print $5 "|"}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} "Fan_SYS5_unc=${spec_temp} RPM
${spec_temp} Run cat Spec.txt |grep Fan_SYS6 |sed -n '$p'|awk '{print $3 "|"}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} "Fan_SYS6_uc=${spec_temp} RPM
${spec_temp} Run cat Spec.txt |grep Fan_SYS6 |sed -n '$p'|awk '{print $5 "|"}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} "Fan_SYS6_unc=${spec_temp} RPM
${spec_temp} Run cat Spec.txt |grep Fan_SYS7 |sed -n '$p'|awk '{print $3 "|"}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} "Fan_SYS7_uc=${spec_temp} RPM
${spec_temp} Run cat Spec.txt |grep Fan_SYS7 |sed -n '$p'|awk '{print $5 "|"}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} "Fan_SYS7_unc=${spec_temp} RPM
${spec_temp} Run cat Spec.txt |grep Volt_P3V3 |sed -n '3p'|awk '{print $3 "|"}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} Volt_P3V3_lc=${spec_temp} Volts
${spec_temp} Run cat Spec.txt |grep Volt_P3V3 |sed -n '3p'|awk '{print $4 "|"}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} Volt_P3V3_uc=${spec_temp} Volts
${spec_temp} Run cat Spec.txt |grep Volt_P5V |sed -n '3p'|awk '{print $3 "|"}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} Volt_P5V_lc=${spec_temp} Volts
${spec_temp} Run cat Spec.txt |grep Volt_P5V |sed -n '3p'|awk '{print $4 "|"}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} Volt_P5V_uc=${spec_temp} Volts
${spec_temp} Run cat Spec.txt |grep Volt_P12V |sed -n '$p'|awk '{print $3 "|"}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} Volt_P12V_lc=${spec_temp} Volts
${spec_temp} Run cat Spec.txt |grep Volt_P12V |sed -n '$p'|awk '{print $4 "|"}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} Volt_P12V_uc=${spec_temp} Volts
${spec_temp} Run cat Spec.txt |grep Volt_P1V05 |sed -n '3p'|awk '{print $3 "|"}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} Volt_P1V05_lc=${spec_temp} Volts
${spec_temp} Run cat Spec.txt |grep Volt_P1V05 |sed -n '3p'|awk '{print $4 "|"}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} Volt_P1V05_uc=${spec_temp} Volts
${spec_temp} Run cat Spec.txt |grep Volt_P1V8_AUX |sed -n '$p'|awk '{print $3 "|"}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} Volt_P1V8_AUX_lc=${spec_temp} Volts
${spec_temp} Run cat Spec.txt |grep Volt_P1V8_AUX |sed -n '$p'|awk '{print $4 "|"}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} Volt_P1V8_AUX_uc=${spec_temp} Volts
${spec_temp} Run cat Spec.txt |grep Volt_P3V3_AUX |sed -n '$p'|awk '{print $3 "|"}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} Volt_P3V3_AUX_lc=${spec_temp} Volts
${spec_temp} Run cat Spec.txt |grep Volt_P3V3_AUX |sed -n '$p'|awk '{print $4 "|"}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} Volt_P3V3_AUX_uc=${spec_temp} Volts
${spec_temp} Run cat Spec.txt |grep Volt_P5V_AUX |sed -n '$p'|awk '{print $3 "|"}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} Volt_P5V_AUX_lc=${spec_temp} Volts
${spec_temp} Run cat Spec.txt |grep Volt_P5V_AUX |sed -n '$p'|awk '{print $4 "|"}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} Volt_P5V_AUX_uc=${spec_temp} Volts
${spec_temp} Run cat Spec.txt |grep Volt_P3V_BAT |sed -n '$p'|awk '{print $3 "|"}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} Volt_P3V_BAT_lc=${spec_temp} Volts
${spec_temp} Run cat Spec.txt |grep Volt_P3V_BAT |sed -n '$p'|awk '{print $4 "|"}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} Volt_P3V_BAT_uc=${spec_temp} Volts
${spec_temp} Run cat Spec.txt |grep Volt_VR_CPU0 |sed -n '$p'|awk '{print $3 "|"}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} Volt_VR_CPU0_lc=${spec_temp} Volts
${spec_temp} Run cat Spec.txt |grep Volt_VR_CPU0 |sed -n '$p'|awk '{print $4 "|"}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} Volt_VR_CPU0_uc=${spec_temp} Volts
${spec_temp} Run cat Spec.txt |grep Volt_VR_CPU1 |sed -n '$p'|awk '{print $3 "|"}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} Volt_VR_CPU1_lc=${spec_temp} Volts
${spec_temp} Run cat Spec.txt |grep Volt_VR_CPU1 |sed -n '$p'|awk '{print $4 "|"}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} Volt_VR_CPU1_uc=${spec_temp} Volts
${spec_temp} Run cat Spec.txt |grep Volt_VR_DIMM_AB |sed -n '$p'|awk '{print $3 "|"}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} Volt_VR_DIMM_AB_lc=${spec_temp} Volts
${spec_temp} Run cat Spec.txt |grep Volt_VR_DIMM_AB |sed -n '$p'|awk '{print $4 "|"}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} Volt_VR_DIMM_AB_uc=${spec_temp} Volts
${spec_temp} Run cat Spec.txt |grep Volt_VR_DIMM_CD |sed -n '$p'|awk '{print $3 "|"}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} Volt_VR_DIMM_CD_lc=${spec_temp} Volts
${spec_temp} Run cat Spec.txt |grep Volt_VR_DIMM_CD |sed -n '$p'|awk '{print $4 "|"}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} Volt_VR_DIMM_CD_uc=${spec_temp} Volts
${spec_temp} Run cat Spec.txt |grep Volt_VR_DIMM_EF |sed -n '$p'|awk '{print $3 "|"}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} Volt_VR_DIMM_EF_lc=${spec_temp} Volts
${spec_temp} Run cat Spec.txt |grep Volt_VR_DIMM_EF |sed -n '$p'|awk '{print $4 "|"}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} Volt_VR_DIMM_EF_uc=${spec_temp} Volts
${spec_temp} Run cat Spec.txt |grep Volt_VR_DIMM_GH |sed -n '$p'|awk '{print $3 "|"}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} Volt_VR_DIMM_GH_lc=${spec_temp} Volts
${spec_temp} Run cat Spec.txt |grep Volt_VR_DIMM_GH |sed -n '$p'|awk '{print $4 "|"}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} Volt_VR_DIMM_GH_uc=${spec_temp} Volts
${spec_temp} Run cat Spec.txt |grep "PSU1 Input" |sed -n '2p'|awk '{print $4 "|"}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} "PSU1 Input"_lc=${spec_temp} Watts
${spec_temp} Run cat Spec.txt |grep "PSU2 Input" |sed -n '2p'|awk '{print $4 "|"}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} "PSU2 Input"_lc=${spec_temp} Watts
${spec_temp} Run cat Spec.txt |grep "NVMeSSD_0" |sed -n '2p'|awk '{print $5 "|"}'| tr -d "|"" ""[3]"
Set To Dictionary ${Sensor_Spec} "NVMeSSD_0"_uc=${spec_temp} Watts
${spec_temp} Run cat Spec.txt |grep "NVMeSSD_0" |sed -n '2p'|awk '{print $7 "|"}'| tr -d "|"" ""[3]"
Set To Dictionary ${Sensor_Spec} "NVMeSSD_0"_unc=${spec_temp} Watts
${spec_temp} Run cat Spec.txt |grep "NVMeSSD_1" |sed -n '2p'|awk '{print $5 "|"}'| tr -d "|"" ""[3]"
Set To Dictionary ${Sensor_Spec} "NVMeSSD_1"_uc=${spec_temp} Watts
${spec_temp} Run cat Spec.txt |grep "NVMeSSD_1" |sed -n '2p'|awk '{print $7 "|"}'| tr -d "|"" ""[3]"
Set To Dictionary ${Sensor_Spec} "NVMeSSD_1"_unc=${spec_temp} Watts
LoginBMCWebUIWOProfile
KEY OpenBrowserWOProfile
KEY LoginBMCWebUI
GoToSensorReadingsPage
Wait Until Element Is Visible xpath=//*[@id="LN_SERVER_HEALTH"] 30
Click Element xpath=//*[@id="LN_SERVER_HEALTH"]
Wait Until Element Is Visible xpath=/html/body/div[3]/a[1] 30
Click Element xpath=/html/body/div[3]/a[1]
Select Frame xpath=//*[@id="pageFrame"]
Wait Until Element Is Visible xpath=//*[@id="_infoLeft"]/div/table/tbody/tr[1]/td[1] 30
GoToAllSensors
Click Element xpath=//*[@id="_sensorType"]
Click Element xpath=//*[@id="_sensorType"]/option[1]
Wait Until Element Is Visible xpath=//*[@id="_infoLeft"]/div/table/tbody/tr[1]/td[1] 30
CheckAllSensors
${req_dict} Create Dictionary
: FOR ${INDEX} IN RANGE 1 89
\ Log ${INDEX}
\ Click Element xpath=//*[@id="_infoLeft"]/div/table/tbody/tr[${INDEX}]/td[1]
\ Sleep 0.5
\ Run Keyword And Continue On Failure Element Text Should Be xpath=//*[@id="_infoLeft"]/div/table/tbody/tr[${INDEX}]/td[1] @{Sensor_List}[${INDEX - 1}]
\ Run Keyword And Continue On Failure Element Text Should Be xpath=//*[@id="_infoLeft"]/div/table/tbody/tr[${INDEX}]/td[2] @{Sensor_Status}[${INDEX - 1}]
\ Set Suite Variable ${temp} @{Sensor_List}[${INDEX - 1}]_lc
\ Run Keyword And Continue On Failure Element Text Should Be xpath=//*[@id="_lowerC"] &{Sensor_Spec}[${temp}]
\ Set Suite Variable ${temp} @{Sensor_List}[${INDEX - 1}]_lnc
\ Run Keyword And Continue On Failure Element Text Should Be xpath=//*[@id="_lowerNC"] &{Sensor_Spec}[${temp}]
\ Set Suite Variable ${temp} @{Sensor_List}[${INDEX - 1}]_uc
\ Run Keyword And Continue On Failure Element Text Should Be xpath=//*[@id="_upperC"] &{Sensor_Spec}[${temp}]
\ Set Suite Variable ${temp} @{Sensor_List}[${INDEX - 1}]_unc
\ Run Keyword And Continue On Failure Element Text Should Be xpath=//*[@id="_upperNC"] &{Sensor_Spec}[${temp}]
LogoutBMCWebUI
KEY LogoutBMCWebUI
>-------------------------------------------------------------------------<
Robot Framework Windows
https://www.python.org/downloads/
https://pip.pypa.io/en/stable/installing/
python -m pip install --upgrade robotframework
python -m robot --version
python -m pip install robotframework-selenium2library
python -m pip install -U wxPython
python -m pip install robotframework-ride
https://sourceforge.net/projects/wxpython/files/wxPython/2.8.12.1/
ride.py
>-------------------------------------------------------------------------<
awk tr
ipmitool lan print |grep "MAC Address"|awk -F "MAC Address : " '{print $2}'|tr -d ":"
>-------------------------------------------------------------------------<
SMTP SSL
openssl genrsa -out key.pem 2048
openssl req -new -key key.pem -out request.csr
openssl x509 -req -days 3650 -in request.csr -signkey key.pem -out certificate.pem
https://slproweb.com/products/Win32OpenSSL.html
key.pem
-----BEGIN RSA PRIVATE KEY-----
MIIEpAIBAAKCAQEA32axZAz0Cw9T8nx4Dn0GYSH3Vm/h9leVZxrMPCWlae1pfglQ
V9R6ELcd759Xpfjw5EZPX+yUCA6qeTK/pWPAvHCwePxTO280xwz/rm/pdNl18rMU
4nAnogZ8n6MKugUvmPghS8yYWcRR1MduUAul+tfpg+D0NoSYyTVm5mSftA+gNErW
JIq1eXt+cWgDeSXGQGw7KHLYsQ6HPzwx9869KNi8dFcLbLWio9MxsXx+U9Yyo3LS
gJEircZrWmQaMR0hCkVUcbznukYbcHDcmLuy0ZT4YH6OG82Mcx7WOyYGbz5F/We7
zCPLqist2zJj883KOCH4caGuKck7bDVzLJk32wIDAQABAoIBAQDHM8Td2AcMjaBn
SsGq+aTkm+r2slEk3jgkderDfzYeXEqCzj9L8fTeTspszwLSxkXW5zMD7+qXvKwZ
4jytd2N3JGzXlPeKucCv9VFP9A6R2Q6pWTI4L5XHjk0186Yu9UzZ8/eMpWT8NmhZ
eXNOAPUB1eEtbTuWGWo7kFiu++7EGLd989wpRxFsJMZmVUBVK0cG4CFP3jSYTz4h
z+9TtpMiuXL5ObfsBnapQxPoTAvaJNrrUnFnnCrP3A1J9tVw9iiIfrYGok427sXY
ZHrSmEMGkY/eACXxW94XjDOOuHkIETlNiqabkJYfONO3csyG5N0ls0QMrIGjKjB+
hRwV3BzBAoGBAP763sC5YHIPcYUlQWG6ZXkmuNJZCFHX4UuRkqDELMo6XCHC/ws0
ShHkYbSTOFOn/u7OEw+c7lhsFyJ3Sn8KPlIfqLej1ktRvbe/CzsgGv0fpYxmgWiO
DSDCGAJpbVlWaGsHfOnWgFeZQWuka8Q/sgyiH7IWHb4ucYUA2xZrpbDrAoGBAOBL
e3ob0Pa/GA9PYGtTemAaboR80Md/IuJKKtiDL89oNyLi178Cn5Q38vW9Tcb94Taa
XCO/GkbIVdEZ0sXG7P7G+T6oLDU+9JtrVJobXc8m8QOzMk1wGFXO26exUk8MrqIY
ezUugy18IZmPTI0RwMv8vlcBI405eHtWhSIHyVjRAoGAbkucoadOpegyRdMIxjp3
/IEYf70NkUGd7i9pSuuxKEU4Z05PPsx+oeC1twPb4KwR5cD0k9NhcpRHKZyKeAu5
S5LwS4eugeQ4+cvFEu1fX1EaLnKE1fJkkWAEPL7YE0YCYxHZIdmsqLfdia+VAk4/
OaHDrihM82BpsIvfOYKVKMMCgYEAxFnP8om/WQLY8S4v3kTp8I+zCFCsBLkLtMXw
1DGj/RHikqu66wBE6uA/1VivafB+4+ollzWIr0ZZuf+9QF5wwmk1cOCQMty2Dgjb
uz0R1nLksrSA6MGkzBmWuSrGP2V+y3BbC6d4Nq1gTKnh/ez4tpq/ljLtCIizLGYF
jlD6tsECgYAgd2FxPBkGgpb3dvpILnFyyjYWfDnyXfg03BbzqM667DOYkJM5lt8r
sIeT9WFqvlBraJu84xQV9hK4sNeljf/9oPgMqyw1nQbmIecXp3qYd9sDaDmI4CUo
VQYyAyGvASYdPRy+kMYnIcET0PB28CeSqVVJ2HuJLS+cEQq4eo9NVw==
-----END RSA PRIVATE KEY-----
certificate.pem
-----BEGIN CERTIFICATE-----
MIIDZjCCAk4CCQDLFafK8E1JIDANBgkqhkiG9w0BAQsFADB1MQswCQYDVQQGEwJU
VzELMAkGA1UECAwCVFcxCzAJBgNVBAcMAlRXMRAwDgYDVQQKDAdzaXQuY29tMQsw
CQYDVQQLDAJUVzEQMA4GA1UEAwwHc2l0LmNvbTEbMBkGCSqGSIb3DQEJARYMcm9v
dEBzaXQuY29tMB4XDTE4MDQwOTAyMDExOVoXDTI4MDQwNjAyMDExOVowdTELMAkG
A1UEBhMCVFcxCzAJBgNVBAgMAlRXMQswCQYDVQQHDAJUVzEQMA4GA1UECgwHc2l0
LmNvbTELMAkGA1UECwwCVFcxEDAOBgNVBAMMB3NpdC5jb20xGzAZBgkqhkiG9w0B
CQEWDHJvb3RAc2l0LmNvbTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEB
AN9msWQM9AsPU/J8eA59BmEh91Zv4fZXlWcazDwlpWntaX4JUFfUehC3He+fV6X4
8ORGT1/slAgOqnkyv6VjwLxwsHj8UztvNMcM/65v6XTZdfKzFOJwJ6IGfJ+jCroF
L5j4IUvMmFnEUdTHblALpfrX6YPg9DaEmMk1ZuZkn7QPoDRK1iSKtXl7fnFoA3kl
xkBsOyhy2LEOhz88MffOvSjYvHRXC2y1oqPTMbF8flPWMqNy0oCRIq3Ga1pkGjEd
IQpFVHG857pGG3Bw3Ji7stGU+GB+jhvNjHMe1jsmBm8+Rf1nu8wjy6orLdsyY/PN
yjgh+HGhrinJO2w1cyyZN9sCAwEAATANBgkqhkiG9w0BAQsFAAOCAQEAOOueLDMl
XaCzlNQi+VLCVPY6tZU1E1d2ZVCnuA18jtbajOsCE77VaSVqpHqKelmiFJNF4PqR
ukEZRQPTgRah71fwZ41pgR+l6Qj41aBJ2ekZzX46xMqfXy0pBUjkvFQ1gBVayglK
adG0YNIySIECIBenB/ck095PeAcVuKxj13MXdPdMIUODdc/jL5HiWJBIogCS6kI2
RO54KOH44cW0q2viMhyY8Tn496nifiNBmoGlDRqwojn3JTIFv2cpmLZu5RE+8Nd4
wyrOC3/8R8NKZF42HMUtA1Osh80LIPrU3WwlofiuudzWjsn4rq7kA5T5sZij3YsI
Juo3P2jxBg8mTA==
-----END CERTIFICATE-----
>-------------------------------------------------------------------------<
Red Hat yum
cat << EOF > /etc/yum.repos.d/123.repo
[base]
name=CentOS-Base
baseurl=http://ftp.stu.edu.tw/Linux/CentOS/7/os/x86_64
gpgcheck=0
[updates]
name=CentOS-Updates
baseurl=http://ftp.stu.edu.tw/Linux/CentOS/7/updates/x86_64
gpgcheck=0
[extras]
name=CentOS-Extras
baseurl=http://ftp.stu.edu.tw/Linux/CentOS/7/extras/x86_64
gpgcheck=0
[centosplus]
name=CentOS-Plus
baseurl=http://ftp.stu.edu.tw/Linux/CentOS/7/centosplus/x86_64
gpgcheck=0
enabled=0
EOF
cat << EOF > /etc/yum.repos.d/google-x86_64.repo
[google64]
name=Google - x86_64
baseurl=http://dl.google.com/linux/rpm/stable/x86_64
enabled=1
gpgcheck=1
gpgkey=https://dl-ssl.google.com/linux/linux_signing_key.pub
EOF
yum --enablerepo=extras install epel-release -y
yum install -y google-chrome-stable
google-chrome-stable --no-sandbox
echo -e "[daemon]\nAutomaticLoginEnable=True\nAutomaticLogin=root" > /etc/gdm/custom.conf
virsh net-destroy default
vim /etc/gdm/custom.conf
[daemon]
AutomaticLoginEnable=True
AutomaticLogin=root
virsh net-list
virsh net-destroy default
virsh net-undefine default
service libvirtd restart
>-------------------------------------------------------------------------<
DISPLAY
ps e | grep -Po " DISPLAY=[\.0-9A-Za-z:]* " | sort -u
DISPLAY=:0 firefox
export DISPLAY=:1
Xvfb :1 -screen 0 1024x768x16 &
pkill -9 -u
>-------------------------------------------------------------------------<
test
#!/bin/bash
rm -rf ./log;
mkdir ./log;
bmc_up_time="180"
bmc_list=$1
ipmitool user list 1 > userlist1.txt;
main(){
for i in
do
date
sh=
echo $sh
ver=
echo $ver
./Yafuflash2 -vyes -pc -cd $sh
if [ $? -eq 0 ]; then
echo "Yafuflash2 PASS";
else
echo "Yafuflash2 FAIL";
exit 1
fi
echo "Wait BMC up ($bmc_up_time seconds)";
for j in
do
echo -ne "$j\r";
sleep 1;
done
echo -ne '\n'
echo "Start to check sdr,mc info,Firmware Revision,user list 1"
mkdir ./log/$i
sdrpass="0"
mcinfopass="0"
verpass="0"
userpass="0"
k="0"
while [ $k -lt 5 ]
do
ipmitool sdr | awk -F"|" '{print $1 $3}' > ./log/$i/sdr.txt;
ipmitool mc info > ./log/$i/mcinfo.txt;
ipmitool user list 1 > ./log/$i/userlist1.txt;
sdrnl=
if [ "$sdrnl" -gt 5 ]; then
echo "sdr check PASS";
let "sdrpass=1";
else
echo "Check Failed on sdr";
fi
mcinfonl=
if [ "$mcinfonl" -gt 5 ]; then
echo "mc_info check PASS";
let "mcinfopass=1";
else
echo "Check Failed on mc_info";
fi
vernl=
if [ "$vernl" == "$ver" ]; then
echo "Firmware_Revision PASS";
let "verpass=1";
else
echo "Check Failed on Firmware_Revision";
fi
diff ./userlist1.txt ./log/$i/userlist1.txt
if [ $? -eq 0 ]; then
echo "user list PASS";
let "userpass=1";
else
echo "user list FAIL";
fi
if [ "$sdrpass" == "1" ] && [ "$mcinfopass" == "1" ] && [ "$verpass" == "1" ] && [ "$userpass" == "1" ]; then
echo "LOOP $i PASS";
break
fi
let "k++";
echo "Wail 3 seconds to recheck";
for j in
do
echo -ne "$j\r";
sleep 1
done
echo -ne '\n';
echo "recheck $k times";
done
if [ "$sdrpass" != "1" ] || [ "$mcinfopass" != "1" ] || [ "$verpass" != "1" ] || [ "$userpass" != "1" ]; then
echo "LOOP $i FAIL";
exit 1
fi
done
}
main 2>&1 | tee -a "running.log"
var fs = require('fs');
var http = require('http');
var https = require('https');
var express = require('express');
var bodyParser = require('body-parser');
var app = express();
var privateKey = fs.readFileSync('key.pem', 'utf8');
var certificate = fs.readFileSync('cert.pem', 'utf8');
var credentials = { key: privateKey, cert: certificate, passphrase: '123456' };
var a=1;
app.get('/email', function (req, res) {
var ip = req.headers['x-forwarded-for'] || req.connection.remoteAddress;
console.log(ip);
if (a > 9) {
a=0;
}
console.log(a);
res.end(a.toString());
a++;
});
app.use(bodyParser.urlencoded({ extended: false }));
app.use(bodyParser.json());
app.post('/', function (req, res) {
console.log(JSON.stringify(req.body));
res.end("OK");
});
var httpServer = http.createServer(app);
var httpsServer = https.createServer(credentials, app);
httpServer.listen(80);
httpsServer.listen(443);
>-------------------------------------------------------------------------<
robot py
from robot.libraries.BuiltIn import BuiltIn
from robot.output import librarylogger
from robot.libraries.OperatingSystem import OperatingSystem
EXECDIR = BuiltIn().get_variable_value("${EXECDIR}")
listdir = OperatingSystem().list_directory(EXECDIR,'Config*',False)
for x in listdir:
librarylogger.write(x, 'INFO', False)
listfile = OperatingSystem().list_directory(EXECDIR+"/"+x,'*.robot',False)
for y in listfile:
librarylogger.write(EXECDIR+"/"+x+"/"+y, 'INFO', False)
BuiltIn().import_resource(EXECDIR+"/"+x+"/"+y)
def log_hello(self):
logger.console('hello')
https://stackoverflow.com/questions/...ables-from-python-library-code
>-------------------------------------------------------------------------<
Notepad++
(?s)\A(?!.*?(?<!\w)(KEY_ALL.robot)(?!\w)).*
(?s)\A((?!Use API site scope).)+\z
https://notepad-plus-plus.org/commun...that-do-not-contain-some-words
http://jeffery062.blogspot.com/2013/02/notepad-regular-expression.html
>-------------------------------------------------------------------------<
XPath Reference
ancestor
ancestor-or-self
attribute
child
descendant
descendant-or-self
following
following-sibling
parent
preceding
preceding-sibling
self
https://developer.mozilla.org/zh-CN/docs/Web/XPath/Axes
>-------------------------------------------------------------------------<
ubuntu
vim /etc/ssh/sshd_config
PermitRootLogin yes
service ssh restart
--------------------------------------------------
chmod 777 /etc/sudoers
vim /etc/sudoers
%sudo ALL=(ALL:ALL) NOPASSWD:ALL
chmod 440 /etc/sudoers
--------------------------------------------------
ubuntu disable ipv6
net.ipv6.conf.all.disable_ipv6 = 1
net.ipv6.conf.default.disable_ipv6 = 1
net.ipv6.conf.lo.disable_ipv6 = 1
sysctl -p
--------------------------------------------------
apt install python
apt install python-pip
apt install libsdl1.2-dev
pip install pypubsub
pip install robotframework
pip install robotframework-ride==1.7.4a1
pip install -U \
-f https://extras.wxpython.org/wxPython4/extras/linux/gtk3/ubuntu-18.04 \
wxPython
--------------------------------------------------
git 永久記憶帳密
git config --global credential.helper store
--------------------------------------------------
a=0;
for (i=2;i<1000;i++){
for (j=2,k=0;j<i;j++){
if (i%j === 0){
k=1;
break;
}
}
if (k === 0) {
a++;
console.log(i);
}
}
console.log(a);
>-------------------------------------------------------------------------<
docker
#Dockerfile
FROM alpine
RUN apk --no-cache add tzdata
RUN apk --no-cache add net-snmp
RUN cp /usr/share/zoneinfo/Asia/Taipei /etc/localtime
RUN echo 'disableAuthorization yes' > /etc/snmp/snmptrapd.conf
VOLUME ["/etc/snmp/","/var/lib/net-snmp/","/root","/tmp"]
EXPOSE 162
CMD ["snmptrapd","-Lf","/tmp/snmptrap.txt","-f","-n","-t","-On","-C","-c","/etc/snmp/snmptrapd.conf","0.0.0.0","::"]
---------------------------------------------------------------------------
docker build -t snmptrapd .
docker container ls
docker container stop trap1
brctl show
docker stop $(docker ps -aq)
docker rm $(docker ps -aq)
docker rmi $(docker images -q)
docker attach trap1
docker exec -it trap1 sh
docker network create -d macvlan --subnet=192.168.210.0/25 --gateway=192.168.210.126 --ipv6 --subnet=2017:401::0/32 --gateway=2017:401::254 -o parent=ens160 mynet
docker run --net=mynet --ip=192.168.210.1 --ip6=2017:401::1 -itd --rm -p 162:162/udp -v /tmp/snmptrapd1:/tmp -v /etc/snmp:/etc/snmp --name snmptrapd1 snmptrapd
docker run --net=mynet --ip=192.168.210.2 --ip6=2017:401::2 -itd --rm -p 162:162/udp -v /tmp/snmptrapd2:/tmp -v /etc/snmp:/etc/snmp --name snmptrapd2 snmptrapd
docker run --net=mynet --ip=192.168.210.3 --ip6=2017:401::3 -itd --rm -p 162:162/udp -v /tmp/snmptrapd3:/tmp -v /etc/snmp:/etc/snmp --name snmptrapd3 snmptrapd
docker run --net=mynet --ip=192.168.210.4 --ip6=2017:401::4 -itd --rm -p 162:162/udp -v /tmp/snmptrapd4:/tmp -v /etc/snmp:/etc/snmp --name snmptrapd4 snmptrapd
docker run --net=mynet --ip=192.168.210.5 --ip6=2017:401::5 -itd --rm -p 162:162/udp -v /tmp/snmptrapd5:/tmp -v /etc/snmp:/etc/snmp --name snmptrapd5 snmptrapd
docker run --net=mynet --ip=192.168.210.6 --ip6=2017:401::6 -itd --rm -p 162:162/udp -v /tmp/snmptrapd6:/tmp -v /etc/snmp:/etc/snmp --name snmptrapd6 snmptrapd
docker run --net=mynet --ip=192.168.210.7 --ip6=2017:401::7 -itd --rm -p 162:162/udp -v /tmp/snmptrapd7:/tmp -v /etc/snmp:/etc/snmp --name snmptrapd7 snmptrapd
docker run --net=mynet --ip=192.168.210.8 --ip6=2017:401::8 -itd --rm -p 162:162/udp -v /tmp/snmptrapd8:/tmp -v /etc/snmp:/etc/snmp --name snmptrapd8 snmptrapd
docker run --net=mynet --ip=192.168.210.9 --ip6=2017:401::9 -itd --rm -p 162:162/udp -v /tmp/snmptrapd9:/tmp -v /etc/snmp:/etc/snmp --name snmptrapd9 snmptrapd
docker exec -it trap1 sh
docker container inspect trap1
>-------------------------------------------------------------------------<
node-fetch
const fetch = require('node-fetch');
var lastid = "";
var title_list = [];
var id_list = [];
var output = "";
dofetch('https://www.dcard.tw/_api/forums/whysoserious/posts?popular=false&limit=100')
function dofetch(url) {
fetch(url)
.then(res => res.json())
.then(function (json) {
dofilter(json)
})
}
function dofilter(res) {
lastid = res[99].id
let res_f = res.filter(res => res.school == "中國文化大學" && res.department == "法律學系");
for (var i = 0; i < res_f.length; ++i) {
title_list.push(res_f[i].title);
id_list.push(res_f[i].id);
}
if (title_list.length < 3) {
console.log(lastid)
console.log(title_list.length)
dofetch('https://www.dcard.tw/_api/forums/whysoserious/posts?popular=false&limit=100' + '&before=' + lastid)
} else {
for (var i = 0; i < title_list.length; ++i) {
output = output + title_list[i];
output = output + "\r\n";
output = output + "https://www.dcard.tw/f/whysoserious/p/" + id_list[i];
output = output + "\r\n";
}
console.log(output)
}
}
>-------------------------------------------------------------------------<
radvd netplan nsupdate
vim /etc/radvd.conf
interface ens160
{
AdvSendAdvert on;
prefix 2018:1:1:1::/64
{
AdvOnLink on;
AdvAutonomous on;
AdvRouterAddr off;
};
};
service radvd restart
service radvd status
systemctl enable radvd
vim /etc/netplan/50-cloud-init.yaml
network:
version: 2
ethernets:
ens160:
accept-ra: no
addresses:
- 192.168.16.1/24
- 2018:1:1:1::1/64
gateway4: 193.168.16.254
gateway6: 2018:1:1:1::1
match:
macaddress: 00:0c:29:9f:c0:95
set-name: ens160
nameservers:
addresses: [8.8.8.8]
vim /etc/bind/named.conf.default-zones
zone "sitddns.com" {
type master;
file "/etc/bind/db.sitddns";
allow-transfer {any;};
allow-query {any;};
allow-update {any;};
check-names ignore;
};
vim /etc/apparmor.d/usr.sbin.named
/etc/bind/** rw,
chmod -R 777 /etc/bind
vim /etc/bind/db.sitddns
$TTL 3600
@ IN SOA ns1.sitddns.com. root.sitddns.com. (
190710 ; Serial
3600 ; Refresh
300 ; Retry
3600000 ; Expire
3600 ) ; Negative Cache TTL
sitddns.com. IN NS ns1.sitddns.com.
ns1.sitddns.com. IN A 192.168.16.1
sitddns.com. IN A 192.168.16.1
www.sitddns.com. IN CNAME sitddns.com.
vim /etc/dhcp/dhcpd.conf
authoritative;
log-facility local7;
default-lease-time 600;
max-lease-time 7200;
option domain-name "sitddns.com";
option domain-name-servers 192.168.16.1;
ddns-updates on;
ddns-update-style standard;
ddns-domainname "sitddns.com.";
update-optimization off;
update-conflict-detection false;
allow client-updates;
zone sitddns.com. {
primary 192.168.16.1;
}
subnet 192.168.16.0 netmask 255.255.255.0 {
range 192.168.16.5 192.168.16.250;
option routers 192.168.16.1;
}
vim /etc/dhcp/dhcpd6.conf
authoritative;
log-facility local7;
allow leasequery;
default-lease-time 2592000;
preferred-lifetime 604800;
option dhcp-renewal-time 3600;
option dhcp-rebinding-time 7200;
option dhcp6.domain-search "sitddns.com";
option dhcp6.name-servers 2018:1:1:1::1;
ddns-updates on;
ddns-update-style standard;
ddns-domainname "sitddns.com.";
update-optimization off;
update-conflict-detection false;
allow client-updates;
zone sitddns.com. {
primary 192.168.16.1;
}
subnet6 2018:1:1:1::/64 {
range6 2018:1:1:1::5 2018:1:1:1::9999;
}
option dhcp6.info-refresh-time 21600;
vim /etc/default/isc-dhcp-server
service isc-dhcp-server restart
service isc-dhcp-server status
service isc-dhcp-server6 restart
service isc-dhcp-server6 status
service bind9 restart
service bind9 status
# nsupdate
> server 127.0.0.1
> update delete www.sit.com A
> update add www.sit.com 600 A 192.168.1.1
> send
> quit
>-------------------------------------------------------------------------<
find json xpath
from robot.api import logger
class ff(object):
ROBOT_LIBRARY_SCOPE = 'TEST SUITE'
def __init__(self):
def traverse(self, path, obj):
self.list_temp = []
cnt = -1
if isinstance(obj, dict):
d = obj
for k, v in d.items():
if isinstance(v, dict):
self.traverse("{path}.{k}".format(path=path, k=k),v)
elif isinstance(v, list):
self.traverse("{path}.{k}".format(path=path, k=k),v)
else:
self.list_temp.append("{path}.{k} => {v}".format(path=path, k=k, v=v))
if isinstance(obj, list):
li = obj
for e in li:
cnt += 1
if isinstance(e, dict):
self.traverse("{path}[{cnt}]".format(path=path, cnt=cnt), e)
elif isinstance(e, list):
self.traverse("{path}[{cnt}]".format(path=path, cnt=cnt), e)
else:
self.list_temp.append("{path}[{cnt}] => {e}".format(path=path, cnt=cnt, e=e))
return self.list_temp
def jsontolist(self,obj):
self.traverse ("root",obj)
from robot.api.deco import keyword
@keyword
def find_jsonpath_of_specific_value(json_obj, specific_value, path=None, list_temp=None):
if path is None:
path = ''
if list_temp is None:
list_temp = []
count = -1
if isinstance(json_obj, dict):
dict_obj = json_obj
for key, value in dict_obj.items():
temp_path = "{path}.['{key}']".format(path=path, key=key)
if isinstance(value, (dict, list)):
find_jsonpath_of_specific_value(value, specific_value, temp_path, list_temp)
else:
if value == specific_value:
list_temp.append(temp_path)
elif isinstance(json_obj, list):
list_obj = json_obj
for element in list_obj:
count += 1
temp_path = "{path}[{count}]".format(path=path, count=count)
if isinstance(element, (dict, list)):
find_jsonpath_of_specific_value(element, specific_value, temp_path, list_temp)
else:
if element == specific_value:
list_temp.append(temp_path)
return list_temp
>-------------------------------------------------------------------------<
netplan
vim /etc/netplan/
network:
ethernets:
ens160:
addresses:
- 192.148.1.1/16
- 2017:17::1/128
gateway4: 192.148.255.254
gateway6: fe80::3efd:feff:fe9e:bd98
nameservers:
addresses: [168.95.1.1,8.8.8.8]
dhcp4: false
dhcp6: false
version: 2
renderer: NetworkManager
netplan try
netplan apply
>-------------------------------------------------------------------------<
lowdb
const express = require('express');
const bodyParser = require('body-parser');
const low = require('lowdb');
const FileAsync = require('lowdb/adapters/FileAsync');
const app = express();
app.use(bodyParser.json())
const adapter = new FileAsync('db.json');
const { exec } = require('child_process');
var https = require('https');
const fs = require('fs');
low(adapter)
.then(db => {
app.get('/getsnmptrapd/:ip', (req, res) => {
console.log("\n get getsnmptrapd")
console.log(new Date().toLocaleDateString() + " " + new Date().toLocaleTimeString())
console.log(req.params.ip);
db.get('snmptrapd').filter((v) => { return v.using < Date.now() }).map('id').value().forEach((i) => { db.get('snmptrapd').find({ id: i }).assign({ using: 0 }).write() });
var unused = db.get('snmptrapd').find({ using: 0 }).value()
var unused_id = unused == undefined ? 0 : unused.id;
console.log("unused_id: " + unused_id);
var list1 = ['2', '3', '4', '5', '6', '7', '8', '9'];
if (list1.indexOf(unused_id) > -1) {
//7200000 2hr
db.get('snmptrapd').find({ id: unused_id }).assign({ using: Date.now() + 7200000, tester: req.params.ip }).write()
var output = db.get('snmptrapd').find({ id: unused_id }).value()
res.status(200).send(output);
} else {
res.status(500).send("sold out");
}
})
app.get('/releasesnmptrapd/:id', (req, res) => {
console.log("\n get releasesnmptrapd")
console.log(new Date().toLocaleDateString() + " " + new Date().toLocaleTimeString())
console.log(req.params.id);
db.get('snmptrapd').find({ id: req.params.id }).assign({ using: 0, tester: "" }).write()
res.status(200).send("released");
})
app.get('/getsmtp/:ip', (req, res) => {
console.log("\n get getsmtp")
console.log(new Date().toLocaleDateString() + " " + new Date().toLocaleTimeString())
console.log(req.params.ip);
db.get('smtp').filter((v) => { return v.using < Date.now() }).map('id').value().forEach((i) => { db.get('smtp').find({ id: i }).assign({ using: 0 }).write() });
var unused = db.get('smtp').find({ using: 0 }).value()
var unused_id = unused == undefined ? 0 : unused.id;
console.log("unused_id: " + unused_id);
var list1 = ['1', '2', '3', '4', '5', '6', '7', '8', '9'];
if (list1.indexOf(unused_id) > -1) {
//7200000 2hr
db.get('smtp').find({ id: unused_id }).assign({ using: Date.now() + 7200000, tester: req.params.ip }).write()
var output = db.get('smtp').find({ id: unused_id }).value()
res.status(200).send(output);
} else {
res.status(500).send("sold out");
}
})
app.get('/releasesmtp/:id', (req, res) => {
console.log("\n get releasesmtp")
console.log(new Date().toLocaleDateString() + " " + new Date().toLocaleTimeString())
console.log(req.params.id);
db.get('smtp').find({ id: req.params.id }).assign({ using: 0, tester: "" }).write()
res.status(200).send("released");
})
app.get('/getlogserver/:ip', (req, res) => {
console.log("\n get getlogserver")
console.log(new Date().toLocaleDateString() + " " + new Date().toLocaleTimeString())
console.log(req.params.ip);
db.get('logserver').filter((v) => { return v.using < Date.now() }).map('id').value().forEach((i) => { db.get('logserver').find({ id: i }).assign({ using: 0 }).write() });
var unused = db.get('logserver').find({ using: 0 }).value()
var unused_id = unused == undefined ? 0 : unused.id;
console.log("unused_id: " + unused_id);
var list1 = ['1'];
if (list1.indexOf(unused_id) > -1) {
db.get('logserver').find({ id: unused_id }).assign({ using: Date.now() + 180000, tester: req.params.ip }).write()
var output = db.get('logserver').find({ id: unused_id }).value()
res.status(200).send(output);
} else {
res.status(500).send("sold out");
}
})
app.get('/releaselogserver/:id', (req, res) => {
console.log("\n get releaselogserver")
console.log(new Date().toLocaleDateString() + " " + new Date().toLocaleTimeString())
console.log(req.params.id);
db.get('logserver').find({ id: req.params.id }).assign({ using: 0, tester: "" }).write()
res.status(200).send("released");
})
app.get('/getpostserver/:ip', (req, res) => {
console.log("\n get getpostserver")
console.log(new Date().toLocaleDateString() + " " + new Date().toLocaleTimeString())
console.log(req.params.ip);
db.get('postserver').filter((v) => { return v.using < Date.now() }).map('id').value().forEach((i) => { db.get('postserver').find({ id: i }).assign({ using: 0 }).write() });
var unused = db.get('postserver').find({ using: 0 }).value()
var unused_id = unused == undefined ? 0 : unused.id;
console.log("unused_id: " + unused_id);
var list1 = ['1', '2', '3', '4', '5', '6', '7', '8', '9'];
if (list1.indexOf(unused_id) > -1) {
db.get('postserver').find({ id: unused_id }).assign({ using: Date.now() + 180000, tester: req.params.ip }).write()
var output = db.get('postserver').find({ id: unused_id }).value()
res.status(200).send(output);
} else {
res.status(500).send("sold out");
}
})
app.get('/releasepostserver/:id', (req, res) => {
console.log("\n get releasepostserver")
console.log(new Date().toLocaleDateString() + " " + new Date().toLocaleTimeString())
console.log(req.params.id);
db.get('postserver').find({ id: req.params.id }).assign({ using: 0, tester: "" }).write()
res.status(200).send("released");
})
})
.then(() => {
app.listen(80, () => console.log('listening on port 80'))
})
app.get('/', function (req, res) {
res.status(200).send("HI");
});
app.get('/db', function (req, res) {
exec('cat db.json', (error, stdout, stderr) => {
res.status(200).send(JSON.parse(stdout.toString()));
});
});
app.post('/post/:id', function (req, res) {
fs.appendFile('/tmp/post' + req.params.id + '.txt', JSON.stringify(req.body), 'utf8', (err) => {
if (err) throw err;
res.status(200).send("OK");
});
});
app.get('/clearpost/:id', function (req, res) {
exec('echo -n "" > /tmp/post' + req.params.id + '.txt', (error, stdout, stderr) => {
if (error) {
console.error(
return;
}
res.status(200).send("cleared");
});
});
app.get('/getpost/:id', function (req, res) {
exec('cat /tmp/post' + req.params.id + '.txt | jq --slurp --compact-output .', (error, stdout, stderr) => {
if (error) {
console.error(
return;
}
res.status(200).send(stdout.toString());
});
});
app.get('/cleartrap/:id', (req, res) => {
console.log("\n get cleartrap")
console.log(new Date().toLocaleDateString() + " " + new Date().toLocaleTimeString())
exec('echo -n "" > /tmp/snmptrapd' + req.params.id + '/snmptrap.txt', (error, stdout, stderr) => {
if (error) {
console.error(
return;
}
res.status(200).send("cleared");
});
})
app.get('/gettrap/:id', (req, res) => {
console.log("\n get gettrap")
console.log(new Date().toLocaleDateString() + " " + new Date().toLocaleTimeString())
exec('cat /tmp/snmptrapd' + req.params.id + '/snmptrap.txt|tr -d "\\0"|sed -e "s/2019-/\\n2019-/"|sed -e "s/2020-/\\n2020-/"', (error, stdout, stderr) => {
if (error) {
console.error(
return;
}
res.status(200).send(stdout.toString());
});
})
app.get('/clearemail/:smtpip/:email', (req, res) => {
console.log("\n get clearemail")
console.log(new Date().toLocaleDateString() + " " + new Date().toLocaleTimeString())
exec('./clearemail.sh' + " " + req.params.smtpip + " " + req.params.email, (error, stdout, stderr) => {
if (error) {
console.error(
return;
}
res.status(200).send("cleared");
});
})
app.get('/getemail/:smtpip/:email', (req, res) => {
console.log("\n getemail")
console.log(new Date().toLocaleDateString() + " " + new Date().toLocaleTimeString())
exec('./getemail.sh' + " " + req.params.smtpip + " " + req.params.email, (error, stdout, stderr) => {
if (error) {
console.error(
return;
}
res.status(200).send(stdout.toString());
});
})
app.get('/clearsyslog', (req, res) => {
exec('echo -n "" > /var/log/log.txt', (error, stdout, stderr) => {
if (error) {
console.error(
return;
}
res.status(200).send("OK");
});
})
app.get('/getsyslog', (req, res) => {
exec('cat /var/log/log.txt', (error, stdout, stderr) => {
if (error) {
console.error(
return;
}
res.status(200).send(stdout.toString());
});
})
app.post('/trapv3user', (req, res) => {
console.log("\n post trapv3user")
console.log(new Date().toLocaleDateString() + " " + new Date().toLocaleTimeString())
// console.log(req.body.name);
// console.log(req.body.pwd);
// console.log(req.body.auth);
// console.log(req.body.priv);
// console.log(req.body.engineid);
// console.log(req.body.snmpid);
if (req.body.name && req.body.pwd && req.body.auth && req.body.priv && req.body.engineid && req.body.snmpid) {
exec('echo createUser -e ' + req.body.engineid + ' ' + req.body.name + ' ' + req.body.auth + ' \\"' + req.body.pwd + '\\" ' + req.body.priv + '>> /etc/snmp/snmptrapd.conf', (error, stdout, stderr) => {
if (error !== null) {
console.error(
return;
}
exec('docker stop snmptrapd' + req.body.snmpid + ';docker run --net=mynet --ip=192.148.1.' + req.body.snmpid + ' --ip6=2017:17::' + req.body.snmpid + ' -itd --rm -p 162:162/udp -v /tmp/snmptrapd' + req.body.snmpid + ':/tmp -v /etc/snmp:/etc/snmp --name snmptrapd' + req.body.snmpid + ' snmptrapd;' + 'sleep 2;echo -n "" > /tmp/snmptrapd' + req.body.snmpid + '/snmptrap.txt;');
console.log('echo docker stop snmptrapd' + req.body.snmpid + ';docker run --net=mynet --ip=192.148.1.' + req.body.snmpid + ' --ip6=2017:17::' + req.body.snmpid + ' -itd --rm -p 162:162/udp -v /tmp/snmptrapd' + req.body.snmpid + ':/tmp -v /etc/snmp:/etc/snmp --name snmptrapd' + req.body.snmpid + ' snmptrapd;');
res.status(200).send("OK");
});
} else {
res.status(500).send("params error");
}
})
https.createServer({
key: fs.readFileSync('server.key'),
cert: fs.readFileSync('server.cert')
}, app)
.listen(443, function () {
console.log('listening on port 443')
})
>-------------------------------------------------------------------------<
woo
const puppeteer = require('puppeteer');
(async () => {
async function leaveChat() {
await page.evaluate(() => {
document.querySelector('#messageInput').value = '';
document.querySelector('input[value=離開]').click();
document.querySelector('#popup-yes').click();
setTimeout(() => {
document.querySelector('#ensureText').value = 'leave';
document.querySelector('#popup-yes').click();
}, 1);
});
await page.evaluate(() => {
setTimeout(() => {
document.querySelector('#startButton').click();
}, 1000);
});
}
const browser = await puppeteer.launch({
userDataDir: './userdir',
executablePath:
'C:\\Program Files\\Google\\Chrome\\Application\\chrome.exe',
headless: false,
args: [
'--no-proxy-server', '--enable-automation', '--mute-audio', '--window-size=340,520', '--app=https://wootalk.today/'
]
});
const page = (await browser.pages())[0];
// await page.setUserAgent('Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:75.0) Gecko/20100101 Firefox/75.0');
// await page.setUserAgent('Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/80.0.3987.163 Safari/537.36');
// await page.setUserAgent('Mozilla/5.0 (Linux; Android 10; Pixel 4 XL) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/81.0.4044.111 Mobile Safari/537.36');
// await page.setViewport({ width: 400, height: 600 });
await page.emulate(puppeteer.devices['iPhone 4']);
// await page.goto('https://wootalk.today/');
await page.waitForSelector('#startButton');
await page.click('#startButton');
await page._client.on('Network.webSocketFrameReceived', ({ requestId, timestamp, response }) => {
// console.log(response.payloadData);
if (response.payloadData.indexOf('對方離開了') > 0) {
if (this.leaveing != 1) {
this.leaveing = 1
console.log("::::::::::::對方離開了");
leaveChat()
setTimeout(() => {
this.leaveing = 0
}, 100);
}
} else if (response.payloadData.indexOf('[["client_connected"') == 0) {
this.starttime = response.payloadData
this.LastMessageTime = response.payloadData
setTimeout((starttime = response.payloadData) => {
if (starttime == this.starttime && starttime == this.LastMessageTime) {
console.log("::::::::::::不說話");
setTimeout(() => {
leaveChat()
}, 100);
}
}, 10000);
} else if (response.payloadData.indexOf('[["new_message"') == 0 && response.payloadData.indexOf('device') > 0) {
const aRegExp = /\{.*\}/;
const newMessage = JSON.parse(response.payloadData.match(aRegExp));
if (this.LastMessageTime != newMessage.data.time) {
this.LastMessageTime = newMessage.data.time;
if (response.payloadData.indexOf('"sender":2') > 0) {
console.log(newMessage.data.message);
if (newMessage.data.id < 4) {
var substrings = ["男", "叔", "弟", "找", "嗎", "女?", "女?", "女生?"];
if (substrings.some(function (v) { return newMessage.data.message.indexOf(v) >= 0; })) {
console.log("::::::::::::主動離開");
setTimeout(() => {
leaveChat()
}, 1000);
} else if (newMessage.data.id == 0) {
page.evaluate(() => {
const a1 = ["男", "男生", "男的"];
const a2 = ["Hi", "妳好", "安安"];
document.querySelector('#messageInput').value = a1[Math.floor(Math.random() * a1.length)];
document.querySelector('input[value=傳送]').click();
document.querySelector('#messageInput').value = a2[Math.floor(Math.random() * a2.length)];
document.querySelector('input[value=傳送]').click();
});
}
}
}
}
}
});
})();
>-------------------------------------------------------------------------<
kerberos
vim /etc/hosts
192.168.212.224 remote.example.com remote
192.168.212.199 server.example.com server
192.168.212.139 client.example.com client
hostnamectl set-hostname remote.example.com
hostnamectl set-hostname server.example.com
hostnamectl set-hostname client.example.com
kerberos
server
client
server 192.168.16.1
update add remote.example.com 0 A 192.168.212.224
update add server.example.com 0 A 192.168.212.199
update add client.example.com 0 A 192.168.134.207
systemctl start kadmin krb5kdc
systemctl enable kadmin krb5kdc
systemctl status kadmin krb5kdc
netstat -tlunp
systemctl start kadmin
systemctl enable kadmin
systemctl restart chronyd
systemctl enable chronyd
systemctl status chronyd
firewall-cmd --add-service=nfs
firewall-cmd --add-service=nfs --permanent
firewall-cmd --add-rich-rule='rule family="ipv4" source address="192.168.0.0/16" accept'
firewall-cmd --add-rich-rule='rule family="ipv4" source address="192.168.0.0/16" accept' --permanent
systemctl restart nfs-client.target
systemctl enable nfs-client.target
systemctl status rpc-gssd
systemctl stop firewalld.service
systemctl disable firewalld.service
systemctl restart kadmin
systemctl restart kerberos
addprinc -randkey host/remote.example.com
addprinc -randkey host/server.example.com
addprinc -randkey host/client.example.com
addprinc -randkey nfs/remote.example.com
addprinc -randkey nfs/server.example.com
addprinc -randkey nfs/client.example.com
scp remote:/etc/krb5.conf /etc
ktadd host/server.example.com@EXAMPLE.COM
ktadd nfs/server.example.com@EXAMPLE.COM
ktadd -k /root/client.keytab host/client.example.com@EXAMPLE.COM
ktadd -k /root/client.keytab nfs/client.example.com@EXAMPLE.COM
systemctl stop firewalld
systemctl disable firewalld
vim /etc/selinux/config
vim /etc/fstab
systemctl restart nfs-secure
showmount -e server
mount -a
vim /etc/fstab
192.168.212.199:/nfs1 /mnt/nfs nfs defaults,v4.2,sec=krb5p 0 0
mount -t nfs4 -o sec=krb5 server:/nfs1 /mnt/nfs
>-------------------------------------------------------------------------<
pm2
npm install pm2 -g
pm2 start --name app app.js
pm2 startup
pm2 save
pm2 logs [--raw] # Display all processes logs in streaming
pm2 flush # Empty all log files
pm2 reloadLogs # Reload all logs
>-------------------------------------------------------------------------<
ldap
ssl
https://www.server-world.info/en/note?os=Ubuntu_16.04&p=openldap&f=4
log
https://www.openldap.org/doc/admin24/slapdconf2.html
starttls
https://ubuntu.com/server/docs/service-ldap-with-tls
https://docs.oracle.com/cd/E17952_01/mysql-5.5-en/creating-ssl-files-using-openssl.html
https://help.ubuntu.com/community/SecuringOpenLDAPConnections
-----------------------------------------------------------------------
apt install -y slapd ldap-utils
dpkg-reconfigure slapd
vim /etc/ldap/ldap.conf
BASE dc=ex,dc=com
URI ldap:// ldaps://
TLS_CACERT /etc/ldap/sasl2/ca.pem
-----------------------------------------------------------------------
yum -y install openldap openldap-clients openldap-servers
rpm -qa |grep openldap
systemctl stop firewalld
systemctl disable firewalld
systemctl mask --now firewalld
slappasswd -h {SSHA} -s 123456
echo 'local4.* /var/log/ldap.log' >> /etc/rsyslog.conf
service rsyslog restart
ldapadd -Y EXTERNAL -H ldapi:/// -f /etc/openldap/schema/cosine.ldif
ldapadd -Y EXTERNAL -H ldapi:/// -f /etc/openldap/schema/nis.ldif
ldapadd -Y EXTERNAL -H ldapi:/// -f /etc/openldap/schema/inetorgperson.ldif
vim /etc/sysconfig/slapd
-----------------------------------------------------------------------
cn=config.ldif
olcLogLevel: -1
olcDatabase={2}hdb.ldif
olcSuffix: dc=ex,dc=com
olcRootDN: cn=admin,dc=ex,dc=com
olcRootPW: {SSHA}AAN+WziS3s6IxXcY+TagzfkNbNbkndPf
olcSecurity: tls=1
https://askubuntu.com/questions/1210313/openldap-trouble-setting-tls-cipher-list
dn: cn=config
changetype: modify
add: olcTLSCipherSuite
olcTLSCipherSuite: SECURE256:+SECURE128:-VERS-TLS-ALL:+VERS-TLS1.2:+VERS-DTLS1.2:-RSA:-DHE-DSS:-CAMELLIA-128-CBC:-CAMELLIA-256-CBC
-----------------------------------------------------------------------
config.ldif
# AUTO-GENERATED FILE - DO NOT EDIT!! Use ldapmodify.
# CRC32 e35f741b
dn: cn=config
objectClass: olcGlobal
cn: config
olcArgsFile: /var/run/slapd/slapd.args
olcLogLevel: none
olcPidFile: /var/run/slapd/slapd.pid
olcToolThreads: 1
structuralObjectClass: olcGlobal
entryUUID: 0908239a-20c1-103b-87dc-7d261b19268a
creatorsName: cn=config
createTimestamp: 20210324074815Z
entryCSN: 20210324074815.323340Z#000000#000#000000
modifiersName: cn=config
modifyTimestamp: 20210324074815Z
olcTLSCACertificateFile: /etc/ldap/sasl2/ca.pem
olcTLSCertificateFile: /etc/ldap/sasl2/cert.pem
olcTLSCertificateKeyFile: /etc/ldap/sasl2/key.pem
olcTLSCipherSuite: SECURE256:+SECURE128:-VERS-TLS-ALL:+VERS-TLS1.2:+VERS-DTL
S1.2:-RSA:-DHE-DSS:-CAMELLIA-128-CBC:-CAMELLIA-256-CBC
-----------------------------------------------------------------------
ldapwhoami -H ldap://ex.com -x -ZZ
/usr/sbin/slapd -d 1 -h "ldap:/// ldapi:/// ldaps:///" -g openldap -u openldap -F /etc/ldap/slapd.d
-----------------------------------------------------------------------
-----------------------------------------------------------------------
dn: dc=ex,dc=com
dc: ex
objectClass: top
objectClass: dcObject
objectClass: organization
o: ex.com
dn: cn=admin, dc=ex,dc=com
userPassword:: e1NIQX1mRXFOQ2NvM1lxOWg1WlVnbEQzQ1pKVDRsQnM9
description: LDAP administrator
objectClass: simpleSecurityObject
objectClass: organizationalRole
cn: admin
dn: ou=People, dc=ex,dc=com
ou: People
objectClass: organizationalUnit
dn: uid=user1,ou=People, dc=ex,dc=com
loginShell: /bin/bash
gidNumber: 18001
userPassword:: e1NIQX1mRXFOQ2NvM1lxOWg1WlVnbEQzQ1pKVDRsQnM9
uidNumber: 18001
uid: user1
objectClass: top
objectClass: account
objectClass: posixAccount
homeDirectory: /home/user1
cn: user1
dn: uid=user2,ou=People, dc=ex,dc=com
loginShell: /bin/bash
gidNumber: 18002
userPassword:: e1NIQX1mRXFOQ2NvM1lxOWg1WlVnbEQzQ1pKVDRsQnM9
uidNumber: 18002
uid: user2
objectClass: top
objectClass: account
objectClass: posixAccount
homeDirectory: /home/user2
cn: user2
dn: uid=user3,ou=People, dc=ex,dc=com
loginShell: /bin/bash
gidNumber: 18003
userPassword:: e1NIQX1mRXFOQ2NvM1lxOWg1WlVnbEQzQ1pKVDRsQnM9
uidNumber: 18003
uid: user3
objectClass: top
objectClass: account
objectClass: posixAccount
homeDirectory: /home/user3
cn: user3
dn: uid=user4,ou=People, dc=ex,dc=com
loginShell: /bin/bash
gidNumber: 18004
userPassword:: e1NIQX1mRXFOQ2NvM1lxOWg1WlVnbEQzQ1pKVDRsQnM9
uidNumber: 18004
uid: user4
objectClass: top
objectClass: account
objectClass: posixAccount
homeDirectory: /home/user4
cn: user4
dn: uid=user5,ou=People, dc=ex,dc=com
loginShell: /bin/bash
gidNumber: 18005
userPassword:: e1NIQX1mRXFOQ2NvM1lxOWg1WlVnbEQzQ1pKVDRsQnM9
uidNumber: 18005
uid: user5
objectClass: top
objectClass: account
objectClass: posixAccount
homeDirectory: /home/user5
cn: user5
dn: uid=usertest,ou=People, dc=ex,dc=com
loginShell: /bin/bash
gidNumber: 18006
userPassword:: e1NIQX1OT2tOMWRYQUtUK0d1WlI2alc4b0RZVHh3YjQ9
uidNumber: 18006
uid: usertest
objectClass: top
objectClass: account
objectClass: posixAccount
homeDirectory: /home/usertest
cn: usertest
dn: uid=suttest,ou=People, dc=ex,dc=com
loginShell: /bin/bash
gidNumber: 18007
userPassword:: e1NIQX1SNkI1aDFMeHNNaHNISVBoUER5NC9ka1pqbzQ9
uidNumber: 18007
uid: suttest
objectClass: top
objectClass: account
objectClass: posixAccount
homeDirectory: /home/suttest
cn: suttest
dn: uid=redfish,ou=People, dc=ex,dc=com
loginShell: /bin/bash
gidNumber: 18008
userPassword:: e1NIQX1SNkI1aDFMeHNNaHNISVBoUER5NC9ka1pqbzQ9
uidNumber: 18008
uid: redfish
objectClass: top
objectClass: account
objectClass: posixAccount
homeDirectory: /home/redfish
cn: redfish
dn: uid=rr123test,ou=People, dc=ex,dc=com
loginShell: /bin/bash
gidNumber: 18009
userPassword:: e1NIQX1JdFF4MUJEajA1c0ZVMjhUOW1sTVpHNTQwYXc9
uidNumber: 18009
uid: rr123test
objectClass: top
objectClass: account
objectClass: posixAccount
homeDirectory: /home/rr123test
cn: rr123test
dn: uid=rr1234test,ou=People, dc=ex,dc=com
loginShell: /bin/bash
gidNumber: 18010
userPassword:: e1NIQX1aZHY5a2RwRkxxa1plTkh2cTBFMENEcjJQUlk9
uidNumber: 18010
uid: rr1234test
objectClass: top
objectClass: account
objectClass: posixAccount
homeDirectory: /home/rr1234test
cn: rr1234test
dn: ou=Group, dc=ex,dc=com
ou: Group
objectClass: organizationalUnit
dn: cn=group1,ou=Group, dc=ex,dc=com
objectClass: groupOfNames
member: uid=user1,ou=People,dc=ex,dc=com
member: uid=suttest,ou=People,dc=ex,dc=com
member: uid=usertest,ou=People,dc=ex,dc=com
member: uid=rr123test,ou=People,dc=ex,dc=com
member: uid=rr1234test,ou=People,dc=ex,dc=com
member: uid=redfish,ou=People,dc=ex,dc=com
cn: group1
dn: cn=group2,ou=Group, dc=ex,dc=com
objectClass: groupOfNames
member: uid=user2,ou=People,dc=ex,dc=com
cn: group2
dn: cn=group3,ou=Group, dc=ex,dc=com
objectClass: groupOfNames
member: uid=user3,ou=People,dc=ex,dc=com
cn: group3
dn: cn=group4,ou=Group, dc=ex,dc=com
objectClass: groupOfNames
member: uid=user4,ou=People,dc=ex,dc=com
cn: group4
dn: cn=group5,ou=Group, dc=ex,dc=com
objectClass: groupOfNames
member: uid=user5,ou=People,dc=ex,dc=com
cn: group5
dn: cn=admin1, dc=ex,dc=com
userPassword:: e1NIQX1mRXFOQ2NvM1lxOWg1WlVnbEQzQ1pKVDRsQnM9
description: LDAP administrator
objectClass: simpleSecurityObject
objectClass: organizationalRole
cn: admin1
※ 編輯: appappf 時間: 2023-01-04 11:21:17 (台灣)
qemu-img create -f qed ubuntu-base.qed 100G
kvm -cdrom ubuntu-14.10-desktop-amd64.iso -m 2048 ubuntu-base.qed
qemu-img create -f qed -b ubuntu-base.qed ubuntu-d-1.qed 100G &
背景執行
&
ctrl+z
bg 1
fg 1
virsh list
virsh dumpxml
virsh define
virsh start
virsh destroy
載入
virsh save ubuntu-1 ubuntu-1-backup.state
靜態存檔
apt-get install vncviewer
VNC
vncviewer 127.0.0.1:5900
9BDRN-HMGRP-FKMDF-6BWG2-76DGY
44JKhXKfTXuDXZ3NpnMBebXrfDCe6URCVjUcjxNBu1vTMzG5Yso8Jp5bAcTeQmmECLGBzP234zNLVWx996C6yMH49tSXxLw
>-------------------------------------------------------------------------<
SQL
mysql -u root -p test
-p database
SELECT * FROM
table
;select from tablename where conclitional
select sum<ae> from student;
總和
select avg<ae> from student;
平均
select substring<student.tel,1,3> tel-3;
student第1格只顯示前3 表格名稱代換tel-3
select * frome student where age not in <25,35,55>;
java.sql.*
javax.sql.*
JDBC套件
show processlist;
process列表
status;
系統狀況
show databases;
create database test;
drop database test;
use test;
show tables;
show table from 資料庫名稱;
show columns from 資料表名稱;
顯示資料表欄位
顯示資料表欄位設定 : describe 資料表名稱;
顯示某個資料表的索引欄位設定 : show index from 資料表名稱;
新增資料表 : create table 資料表名稱 ( 欄位名稱1 資料型態,欄位名稱2 資料型態 );
新增欄位 : alter table 資料表名稱 add 欄位名稱 資料型態;
修改資料表 : alter table 舊資料表名稱 rename 新資料表名稱;
修改欄位刪除 : alter table 資料表名稱 drop 欄位名稱
刪除資料庫 : drop database 資料庫名稱;
刪除資料表 : drop table 資料表名稱;
刪除欄位 : drop 欄位名稱;
欄位刪除 : alter table 資料表名稱 drop 欄位名稱
>-------------------------------------------------------------------------<
openvpn
step 1
vars.bat.sample
---------------------------------------------------------
---------------------------------------------------------
step 2
init-config.bat
vars.bat
clean-all.bat
build-dh.bat
build-ca.bat
---------------------------------------------------------
step 3
build-key-server.bat server
---------------------------------------------------------
step 4
build-key.bat client
---------------------------------------------------------
---------------------------------------------------------
step 5
server.ovpn
---------------------------------------------------------
port 1194
dev tun
proto tcp
server 10.8.0.0 255.255.255.0
push "redirect-gateway def1 bypass-dhcp"
push "dhcp-option DNS 8.8.8.8"
client-to-client
keepalive 10 120
persist-key
persist-tun
verb 3
<ca>
-----BEGIN CERTIFICATE-----
MIIECjCCA3OgAwIBAgIJAP+gdhdVLiMVMA0GCSqGSIb3DQEBCwUAMIG1MQswCQYD
VQQGEwJVUzELMAkGA1UECBMCQ0ExFTATBgNVBAcTDFNhbkZyYW5jaXNjbzEVMBMG
A1UEChMMRm9ydC1GdW5zdG9uMR0wGwYDVQQLExRNeU9yZ2FuaXphdGlvbmFsVW5p
dDEYMBYGA1UEAxMPRm9ydC1GdW5zdG9uIENBMQ8wDQYDVQQpEwZzZXJ2ZXIxITAf
BgkqhkiG9w0BCQEWEm1lQG15aG9zdC5teWRvbWFpbjAeFw0xNjA1MTYxNTE2NTRa
Fw0yNjA1MTQxNTE2NTRaMIG1MQswCQYDVQQGEwJVUzELMAkGA1UECBMCQ0ExFTAT
BgNVBAcTDFNhbkZyYW5jaXNjbzEVMBMGA1UEChMMRm9ydC1GdW5zdG9uMR0wGwYD
VQQLExRNeU9yZ2FuaXphdGlvbmFsVW5pdDEYMBYGA1UEAxMPRm9ydC1GdW5zdG9u
IENBMQ8wDQYDVQQpEwZzZXJ2ZXIxITAfBgkqhkiG9w0BCQEWEm1lQG15aG9zdC5t
eWRvbWFpbjCBnzANBgkqhkiG9w0BAQEFAAOBjQAwgYkCgYEAuCEqro+i7zrfUalK
Y860Fa6kGQnJWdvB/G+ulz/NJ8EZG8zNKarDKvkaMTEu/whVPUewp4NNxTfvhMjO
53zQBpx/la+S+1MsG25MA8VGJg+acUQrq3mJ7s6AwLKlgJC+Ikb0P5dXTPAZJGbY
P2IyrGc1FFfQl/I0k1E4r+bP7pUCAwEAAaOCAR4wggEaMB0GA1UdDgQWBBSYNQ/X
B94RSbQCrfcrj6l6Y0IxpzCB6gYDVR0jBIHiMIHfgBSYNQ/XB94RSbQCrfcrj6l6
Y0Ixp6GBu6SBuDCBtTELMAkGA1UEBhMCVVMxCzAJBgNVBAgTAkNBMRUwEwYDVQQH
EwxTYW5GcmFuY2lzY28xFTATBgNVBAoTDEZvcnQtRnVuc3RvbjEdMBsGA1UECxMU
TXlPcmdhbml6YXRpb25hbFVuaXQxGDAWBgNVBAMTD0ZvcnQtRnVuc3RvbiBDQTEP
MA0GA1UEKRMGc2VydmVyMSEwHwYJKoZIhvcNAQkBFhJtZUBteWhvc3QubXlkb21h
aW6CCQD/oHYXVS4jFTAMBgNVHRMEBTADAQH/MA0GCSqGSIb3DQEBCwUAA4GBAHws
EeaugL/iRDobk73l7hkP8Kgtp5K58n3wYKJDSUKCtQGIts5ooE34rlW/R+FM/pRW
/QuhWK4AX/uzfwqmXutI43FLUHGoybeKYn+Q3GFmNeqCRUFBi37F/hp7JqmyxGMf
pIebG07iD2i6IWav8KntBnAMSdWdrgT8aDfLBCOP
-----END CERTIFICATE-----
</ca>
<cert>
-----BEGIN CERTIFICATE-----
MIIEdDCCA92gAwIBAgIBATANBgkqhkiG9w0BAQsFADCBtTELMAkGA1UEBhMCVVMx
CzAJBgNVBAgTAkNBMRUwEwYDVQQHEwxTYW5GcmFuY2lzY28xFTATBgNVBAoTDEZv
cnQtRnVuc3RvbjEdMBsGA1UECxMUTXlPcmdhbml6YXRpb25hbFVuaXQxGDAWBgNV
BAMTD0ZvcnQtRnVuc3RvbiBDQTEPMA0GA1UEKRMGc2VydmVyMSEwHwYJKoZIhvcN
AQkBFhJtZUBteWhvc3QubXlkb21haW4wHhcNMTYwNTE2MTUxNzIwWhcNMjYwNTE0
MTUxNzIwWjCBrDELMAkGA1UEBhMCVVMxCzAJBgNVBAgTAkNBMRUwEwYDVQQHEwxT
YW5GcmFuY2lzY28xFTATBgNVBAoTDEZvcnQtRnVuc3RvbjEdMBsGA1UECxMUTXlP
cmdhbml6YXRpb25hbFVuaXQxDzANBgNVBAMTBnNlcnZlcjEPMA0GA1UEKRMGc2Vy
dmVyMSEwHwYJKoZIhvcNAQkBFhJtZUBteWhvc3QubXlkb21haW4wgZ8wDQYJKoZI
hvcNAQEBBQADgY0AMIGJAoGBAKaesQ4y14sOyIYdKBwpnrzwWNLdSnV0zcaFpG45
AN/0rQoXwF4xqRjYHZPHma9cY3vWf98fgp9ZDN27OmUC6ULjEkjBOuRCrM07Lkuj
hECLhiDBqXzMu3ERhtFAWx3aACR/OoDRZ0XwqRZ7uVEFstY34O6nkUBVO2e42dls
3QD9AgMBAAGjggGZMIIBlTAJBgNVHRMEAjAAMBEGCWCGSAGG+EIBAQQEAwIGQDA0
BglghkgBhvhCAQ0EJxYlRWFzeS1SU0EgR2VuZXJhdGVkIFNlcnZlciBDZXJ0aWZp
Y2F0ZTAdBgNVHQ4EFgQUVd7NpL/Q+SXWhYis1W0a+LLQR/QwgeoGA1UdIwSB4jCB
34AUmDUP1wfeEUm0Aq33K4+pemNCMaehgbukgbgwgbUxCzAJBgNVBAYTAlVTMQsw
CQYDVQQIEwJDQTEVMBMGA1UEBxMMU2FuRnJhbmNpc2NvMRUwEwYDVQQKEwxGb3J0
LUZ1bnN0b24xHTAbBgNVBAsTFE15T3JnYW5pemF0aW9uYWxVbml0MRgwFgYDVQQD
Ew9Gb3J0LUZ1bnN0b24gQ0ExDzANBgNVBCkTBnNlcnZlcjEhMB8GCSqGSIb3DQEJ
ARYSbWVAbXlob3N0Lm15ZG9tYWluggkA/6B2F1UuIxUwEwYDVR0lBAwwCgYIKwYB
BQUHAwEwCwYDVR0PBAQDAgWgMBEGA1UdEQQKMAiCBnNlcnZlcjANBgkqhkiG9w0B
AQsFAAOBgQCO9/+a96G6nHi219FfqWerBwErxpfjr4vURu0zW01wdZ8OJZBS2KSi
53tXG+xFDfvdyowqrLK/e3Mp9HDWupdH6tYnxW/+P+EFASsvvwJ8y8T9p/qFMCz5
h+0JiVHcwPHlDZ1Ha1OELIQwUHVsIJmS/FYndd7qRRQl9gQNz+Tbfg==
-----END CERTIFICATE-----
</cert>
<key>
-----BEGIN PRIVATE KEY-----
MIICdwIBADANBgkqhkiG9w0BAQEFAASCAmEwggJdAgEAAoGBAKaesQ4y14sOyIYd
KBwpnrzwWNLdSnV0zcaFpG45AN/0rQoXwF4xqRjYHZPHma9cY3vWf98fgp9ZDN27
OmUC6ULjEkjBOuRCrM07LkujhECLhiDBqXzMu3ERhtFAWx3aACR/OoDRZ0XwqRZ7
uVEFstY34O6nkUBVO2e42dls3QD9AgMBAAECgYEAoo376wBLLU2U8NMNSLyKM4bB
AagHdqQoBeBoVWijo9sP3uLhOIR2lthxsrVvCJi4Lh9MzZ/uTgwQ81owVFAMxTLp
oAOwfaJm2n636F0V8LBwOIgCwb4qXO4i0i7W9OLx14Q7NlTTrpOCfArFu04oBajI
SjDBogLjorZCjX9qawECQQDcoPWd62oqlSOt318jJPmOMKzHcF9NpOlHR0skYEP8
fs0Fb5ssrr4YFssZQEiYKtoGW+3R5kJNU2uZBc0TG9HdAkEAwVUaCZBBH5PmKhcv
fYlFWLLcEcC0HFPyDxmOzI/4+9oKsnPZuEBuxNgXhXnA2NJizTbuhlPpsnTyb3PP
3j5JoQJANjoppIL0OTsm5dl9HLo9zEESdoKcKg1aePaA9ZPjoe/YnHlt/nGEr48K
pE40iZIevGlj7q9VpIPYcmgGm6e+0QJBAKzYSM8ECTUSJVS8Jdk2QKlsPxQgFOa+
pkqZrvF0RkXkSmwA50WzVVTnXSAYGjG+5lZSJi4yF11U8OpzwAQR7AECQDbY+Aj2
IFKSMAJ5Uga8HuQy54antjhubdird+KN5HvZu+8p+QvIkrjruHmQ2WM8pSZG+nYY
pyh//RVij/8illk=
-----END PRIVATE KEY-----
</key>
<dh>
-----BEGIN DH PARAMETERS-----
MIGHAoGBAJxBWOQl17MeUWlHjeAoMD/FLw9qGx1wTRYef+XIKnSUZ88ROXjde9jh
hMKq1VFUlaqJO3uo8knzC//naIWKScEsbnXr91Ms1pmDbF5XEH6f/E5YPQxD59uA
nClSlS3zh6exljLhH5xi4kQUxg7307YWqMoGF75ixZmPkv7mP1q7AgEC
-----END DH PARAMETERS-----
</dh>
---------------------------------------------------------
step 6
client.ovpn
---------------------------------------------------------
client
dev tun
proto tcp
remote 8.8.8.8 1194
nobind
persist-key
persist-tun
verb 3
<ca>
-----BEGIN CERTIFICATE-----
MIIECjCCA3OgAwIBAgIJAP+gdhdVLiMVMA0GCSqGSIb3DQEBCwUAMIG1MQswCQYD
VQQGEwJVUzELMAkGA1UECBMCQ0ExFTATBgNVBAcTDFNhbkZyYW5jaXNjbzEVMBMG
A1UEChMMRm9ydC1GdW5zdG9uMR0wGwYDVQQLExRNeU9yZ2FuaXphdGlvbmFsVW5p
dDEYMBYGA1UEAxMPRm9ydC1GdW5zdG9uIENBMQ8wDQYDVQQpEwZzZXJ2ZXIxITAf
BgkqhkiG9w0BCQEWEm1lQG15aG9zdC5teWRvbWFpbjAeFw0xNjA1MTYxNTE2NTRa
Fw0yNjA1MTQxNTE2NTRaMIG1MQswCQYDVQQGEwJVUzELMAkGA1UECBMCQ0ExFTAT
BgNVBAcTDFNhbkZyYW5jaXNjbzEVMBMGA1UEChMMRm9ydC1GdW5zdG9uMR0wGwYD
VQQLExRNeU9yZ2FuaXphdGlvbmFsVW5pdDEYMBYGA1UEAxMPRm9ydC1GdW5zdG9u
IENBMQ8wDQYDVQQpEwZzZXJ2ZXIxITAfBgkqhkiG9w0BCQEWEm1lQG15aG9zdC5t
eWRvbWFpbjCBnzANBgkqhkiG9w0BAQEFAAOBjQAwgYkCgYEAuCEqro+i7zrfUalK
Y860Fa6kGQnJWdvB/G+ulz/NJ8EZG8zNKarDKvkaMTEu/whVPUewp4NNxTfvhMjO
53zQBpx/la+S+1MsG25MA8VGJg+acUQrq3mJ7s6AwLKlgJC+Ikb0P5dXTPAZJGbY
P2IyrGc1FFfQl/I0k1E4r+bP7pUCAwEAAaOCAR4wggEaMB0GA1UdDgQWBBSYNQ/X
B94RSbQCrfcrj6l6Y0IxpzCB6gYDVR0jBIHiMIHfgBSYNQ/XB94RSbQCrfcrj6l6
Y0Ixp6GBu6SBuDCBtTELMAkGA1UEBhMCVVMxCzAJBgNVBAgTAkNBMRUwEwYDVQQH
EwxTYW5GcmFuY2lzY28xFTATBgNVBAoTDEZvcnQtRnVuc3RvbjEdMBsGA1UECxMU
TXlPcmdhbml6YXRpb25hbFVuaXQxGDAWBgNVBAMTD0ZvcnQtRnVuc3RvbiBDQTEP
MA0GA1UEKRMGc2VydmVyMSEwHwYJKoZIhvcNAQkBFhJtZUBteWhvc3QubXlkb21h
aW6CCQD/oHYXVS4jFTAMBgNVHRMEBTADAQH/MA0GCSqGSIb3DQEBCwUAA4GBAHws
EeaugL/iRDobk73l7hkP8Kgtp5K58n3wYKJDSUKCtQGIts5ooE34rlW/R+FM/pRW
/QuhWK4AX/uzfwqmXutI43FLUHGoybeKYn+Q3GFmNeqCRUFBi37F/hp7JqmyxGMf
pIebG07iD2i6IWav8KntBnAMSdWdrgT8aDfLBCOP
-----END CERTIFICATE-----
</ca>
<cert>
-----BEGIN CERTIFICATE-----
MIIEWjCCA8OgAwIBAgIBAjANBgkqhkiG9w0BAQsFADCBtTELMAkGA1UEBhMCVVMx
CzAJBgNVBAgTAkNBMRUwEwYDVQQHEwxTYW5GcmFuY2lzY28xFTATBgNVBAoTDEZv
cnQtRnVuc3RvbjEdMBsGA1UECxMUTXlPcmdhbml6YXRpb25hbFVuaXQxGDAWBgNV
BAMTD0ZvcnQtRnVuc3RvbiBDQTEPMA0GA1UEKRMGc2VydmVyMSEwHwYJKoZIhvcN
AQkBFhJtZUBteWhvc3QubXlkb21haW4wHhcNMTYwNTE2MTUxNzUyWhcNMjYwNTE0
MTUxNzUyWjCBrDELMAkGA1UEBhMCVVMxCzAJBgNVBAgTAkNBMRUwEwYDVQQHEwxT
YW5GcmFuY2lzY28xFTATBgNVBAoTDEZvcnQtRnVuc3RvbjEdMBsGA1UECxMUTXlP
cmdhbml6YXRpb25hbFVuaXQxDzANBgNVBAMTBmNsaWVudDEPMA0GA1UEKRMGc2Vy
dmVyMSEwHwYJKoZIhvcNAQkBFhJtZUBteWhvc3QubXlkb21haW4wgZ8wDQYJKoZI
hvcNAQEBBQADgY0AMIGJAoGBALxptjZheLvMoPTceR4qu2k/kWCZ8DZqdp/0c300
9CqilLvJPcHhBrfON9ELZDojrJ+NAh4k7B27Hzm4hskLIjjbE+QqmjMKHoFGbSKA
2Fc7OwP7iBqQ2QaiDNaUEZC8tUrq0Ddjo6RTx2LcLd6kiO8N+RfzzEzCiZbYzfBc
SDGtAgMBAAGjggF/MIIBezAJBgNVHRMEAjAAMC0GCWCGSAGG+EIBDQQgFh5FYXN5
LVJTQSBHZW5lcmF0ZWQgQ2VydGlmaWNhdGUwHQYDVR0OBBYEFL6IqbPz5La4Yb2k
DNEKaM/jevTpMIHqBgNVHSMEgeIwgd+AFJg1D9cH3hFJtAKt9yuPqXpjQjGnoYG7
pIG4MIG1MQswCQYDVQQGEwJVUzELMAkGA1UECBMCQ0ExFTATBgNVBAcTDFNhbkZy
YW5jaXNjbzEVMBMGA1UEChMMRm9ydC1GdW5zdG9uMR0wGwYDVQQLExRNeU9yZ2Fu
aXphdGlvbmFsVW5pdDEYMBYGA1UEAxMPRm9ydC1GdW5zdG9uIENBMQ8wDQYDVQQp
EwZzZXJ2ZXIxITAfBgkqhkiG9w0BCQEWEm1lQG15aG9zdC5teWRvbWFpboIJAP+g
dhdVLiMVMBMGA1UdJQQMMAoGCCsGAQUFBwMCMAsGA1UdDwQEAwIHgDARBgNVHREE
CjAIggZjbGllbnQwDQYJKoZIhvcNAQELBQADgYEAM3AULkp6XFRN9yyt/io0etPW
woymXACoIvWIzRLaUQ+ffhZ0QUmJhHVxBLDlEofSpuzHAb4Ad6uyJQGuzdlxsQc5
okFTI2VB5CjaqMvCDQGdrmuig9SPNmCEhtcOHQxiD2B7v+Ah63mPNG8J0SFB3ODW
9jVgj7ddDt8w2r0HNxA=
-----END CERTIFICATE-----
</cert>
<key>
-----BEGIN PRIVATE KEY-----
MIICdwIBADANBgkqhkiG9w0BAQEFAASCAmEwggJdAgEAAoGBALxptjZheLvMoPTc
eR4qu2k/kWCZ8DZqdp/0c3009CqilLvJPcHhBrfON9ELZDojrJ+NAh4k7B27Hzm4
hskLIjjbE+QqmjMKHoFGbSKA2Fc7OwP7iBqQ2QaiDNaUEZC8tUrq0Ddjo6RTx2Lc
Ld6kiO8N+RfzzEzCiZbYzfBcSDGtAgMBAAECgYEAnq49WsFuqGPnrzG8A+8jVbnG
21/qkjnJ3F9JoMqnVP0GXL1Y+N9nBAh2s+VvLRP8f4eHoBGilkuROdCyG8H3uA6/
iv44DV5v9vlPgI1RMDiDN9vgdHgM2M6GZmPjUY9TLw0G5dDRy5vClyCvaYzXj36Y
DNkxZ7ROGfzY3tKLAwECQQDdgSWTp4LtCzWiPObpl4Aq1oIrx/KApe3b8nrnOiT5
6rMkCSjnhw93jz9Kr8ZWqBj6WhNPKw99OAY1NI5p/xbBAkEA2cFIzmCzc2OOUBMB
DK/DLo+5ImU+VBYFbAVTIDTSKZ1YsVObDsUsqtdVQBnEXzg4nMWdRvizU2HaR0dF
bMFh7QJBAL5FeenkMus8fc3nUtPFeCtUKG1DTGSGJFSTbk/B+pFTsp5539FCi17A
hjW52D4IF6y2Q2/2JVADGBIMG2mh3gECQHB9qV70FcBGbf5v0tr68ZncJYffRZOq
zKJBHfBFWUymPGtfBXtb4PdgxmmW5htKr/RNIjLHx9wLcPfhmbvVKwECQFdoYe6g
rKxgLV7jVKABRYgl+LgxMfWc6JRXtk4Eu/okB4Clx8c+HspUh20QrsEJNv/Wc5+D
x58qRzDUjfghLg4=
-----END PRIVATE KEY-----
</key>
---------------------------------------------------------
---------------------------------------------------------
ufw enable
ufw default deny
ufw allow 1194/tcp
ufw allow 1194/udp
vi /etc/default/ufw
-
DEFAULT_FORWARD_POLICY="ACCEPT"
--
vi /etc/ufw/sysctl.conf
-
net/ipv4/ip_forward=1
--
sysctl -p
ufw disable
ufw enable
ufw status
service openvpn restart
iptables -t nat -A POSTROUTING -s 10.8.0.0/24 -o ppp0 -j MASQUERADE
iptables --table nat --list
>-------------------------------------------------------------------------<
redhat
#init 3
多人文字
#init 5
GUI
#init 6
reboot
#timedatectl set-local-rtc 1
硬體時鐘設置為本地時區
#systemctl set-default multi-user.target
#systemctl set-default graphical.target
change runlevel
#gsettings set org.gnome.settings-daemon.plugins.power button-power shutdown
systemctl stop firewalld.service
systemctl disable firewalld.service
blank: does nothing
suspend: makes your system suspend
shutdown: starts a normal issued shutdown procedure
hibernate: hibernates your system
nothing: does nothing
logout: log your user out
>-------------------------------------------------------------------------<
ipmitool
ipmitool -H 192.168.1.1 -U admin -P admin power status
ipmitool -H 192.168.1.1 -U admin -P admin lan print
ipmitool -H 192.168.1.1 -U admin -P admin sensor list
ipmitool -H 192.168.1.1 -U admin -P admin user list
ipmitool -H 192.168.1.1 -U admin -P admin bmc reset cold
ipmitool sel time get
BMC的時間
ipmitool sel time set "mm/dd/yyyy hh:mm:ss"
設時間
ipmitool power status
查看目前的電源狀況
ipmitool power on
開機
ipmitool power off
關機,是暴力關電,所以OS不是正常結束
ipmitool power reset
如同按下reset
ipmitool power cycle
似乎是讓系統先shutdown之後,過一秒再power on,這樣就不必常跑機房了
ipmitool power soft
透過ACPI讓OS shutdown或restart或log off
ipmitool chassis status
system status包含電源訊息,system狀況
ipmitool chassis identify
可以在機房機架中找到主機,燈號會閃15秒
ipmitool chassis restart_cause
查看上次系統重啟的原因
ipmitool -H 192.168.114.239 -U admin -P admin mc guid
ipmitool -H 192.168.114.239 -U admin -P admin raw 0x06 0x08
BMC-IPMI-mc_Device GUID
$ ipmitool -U username -P password -H 192.168.1.5 chassis power on
$ ipmitool -U username -P password -H 192.168.1.5 chassis power off
$ ipmitool -U username -P password -H 192.168.1.5 chassis power cycle
$ ipmitool -U username -P password -H 192.168.1.5 chassis power soft
$ ipmitool -U username -P password -H 192.168.1.5 chassis power status
$ ipmitool -U username -P password -H 192.168.1.5 chassis bootdev pxe
$ ipmitool -U username -P password -H 192.168.1.5 chassis bootdev bios
$ ipmitool -U username -P password -H 192.168.1.5 chassis bootdev disk
$ ipmitool -U username -P password -H 192.168.1.5 bmc info
$ ipmitool -U username -P password -H 192.168.1.5 lan print
$ ipmitool -U username -P password -H 192.168.1.5 lan set 1 ipsrc static
$ ipmitool -U username -P password -H 192.168.1.5 lan set 1 ipaddr 192.168.1.5
$ ipmitool -U username -P password -H 192.168.1.5 lan set 1 netmask 255.255.255.0
$ ipmitool -U username -P password -H 192.168.1.5 lan set 1 defgw ipaddr 192.168.1.254
$ ipmitool -U username -P password -H 192.168.1.5 mc info
$ ipmitool -U username -P password -H 192.168.1.5 mc reset cold
$ ipmitool -U username -P password -H 192.168.1.5 sdr
$ ipmitool -U username -P password -H 192.168.1.5 sel list
1. ipmitool -I lanplus -H <host> -U admin -P admin user set name 5 bob
2. ipmitool -I lanplus -H <host> -U admin -P admin user set password 5 bad_pass
3. ipmitool -I lanplus -H <host> -U admin -P admin user enable 5
4. ipmitool -I lanplus -H <host> -U admin -P admin channel setaccess 1 5 ipmi=on privilege=4
5. ipmitool -I lanplus -H <host> -U bob -P bad_pass user list 1
FB專用BMC AC斷電 ipmitool raw 0x06 0x52 0x0f 0x22 0x00 0xd9
>-------------------------------------------------------------------------<
power cycle
dmesg -C
echo "" > /var/log/messages
ipmitool sel clear
rm -rf /root/QuickHWCheck
./RunMe.sh
timedatectl set-local-rtc 1
systemctl set-default multi-user.target
gsettings set org.gnome.settings-daemon.plugins.power button-power shutdown
>-------------------------------------------------------------------------<
ESXI
Disable firewall
#esxcli network firewall get
#esxcli entwork firewall set --enabled false
Install Driver
There two types of ESXi driver
– vib
– offline_bundle
The related command
– Driver list
#esxcli software vib list
– Driver install
#esxcli software vib install –v /vib_stored_full_path.vib
#esxcli software vib install –d /offline_bundle_full_path.zip
– Drvier unistall
#esxcli software vib remove –n driver_name
OS event check(using msg_check)
Download message check tool from VRC
sit_tools>linux>utility>message-check
Download VMW white list from VRC
sit_tools>virtualization>utility>message-check
OOB command
#./msg_check.sh -2 -h esxi_ip -w white_list.csv -vmw
If have error message, please get VM-support log from ESXi
1. Open any web browser (eg: Firefox)
2. Enter URL as below https://your_ESXi_IP/cgi-bin/vm-support.cgi
3. save this log to below path \\ccbu01\cc-share\Public_Zone\VMware_log
TM02L-8YH5M-L8P81-0M2R2-80U04
JH43M-FUJ53-68Y80-0C0HK-3XEMN
>-------------------------------------------------------------------------<
bash
http://linuxdiary.blogspot.tw/2007/10/blog-post_30.html
參數
說明
a && b
如果 a 是真,則執行 b。如果 a 是假,則不執行 b。
a || b
如果 a 是假,則執行 b。如果 a 是真,則不執行 b。
a && b || c
如果 a 是真,則執行 b,如果 a 是假,則執行 c。
因為 a 為假時,a && b 為假,所以會去執行 c。
a && b && c && d && e && f || g
如果 a~f 有一個是假,則執行 c。
中括號的條件判斷
使用中括號必須要特別注意,因為中括號用在很多地方,包括萬用字元與正規表示法等等,所以如果要在 bash 的語法當中使用中括號作為 shell 的判斷式時,必須要注意中括號的兩端需要有空白字元來分隔喔!
檔案判斷
參數
說明
範列
-r file
檔案可讀為真。
[ -r /tmp/aaa ]
-w file
檔案可寫為真。
[ -w /tmp/aaa ]
-x file
檔案可執行為真。
[ -x /tmp/aaa ]
-f file
檔案為正規檔案為真。
[ -f /tmp/aaa ]
-d file
檔案為目錄為真。
[ -d /tmp/aaa ]
-c file
檔案為字元裝置為真。
[ -c /dev/aaa ]
-b file
檔案為區塊裝置為真。
[ -b /dev/aaa ]
-s file
檔案大小大於0為真。
[ -s /tmp/aaa ]
-t file
当文件描述符(默认为1)指定的设备为终端时为真。
[ -t /tmp/aaa ]
-p file
檔案為管道為真。
[ -p /tmp/aaa ]
-h file
檔案為符號連結為真。
[ -h /tmp/aaa ]
-L file
檔案為符號連結為真。
[ -L /tmp/aaa ]
字串比較
參數
說明
範列
"字串" = "字串"
比較二個字串相等為真。
[ "$a" = "$b" ]
"字串" == "字串"
比較二個字串相等為真。
[ "$a" == "$b" ]
"字串" != "字串"
比較二個字串不同為真。
[ "$a" != "$b" ]
-z "字串"
空字串為真。
[ -z "$b" ]
-n "字串"
非空字串為真。
[ -n "$b" ]
數字比較
參數
說明
範列
-eq
數字相等為真。
[ "$a" -eq "$b" ]
-ne
數字不相等為真。
[ "$a" -ne "$b" ]
-gt
數字較大為真。
[ "$a" -gt "$b" ]
-ge
數字較大或相等為真。
[ "$a" -ge "$b" ]
-lt
數字較小為真。
[ "$a" -lt "$b" ]
-le
數字較小或相等為真。
[ "$a" -le "$b" ]
多重條件比較
參數
說明
範列
-a
條件同時成立為真。
[ -r file -a -x file ]
-o
條件只要一個成立為真。
[ -r file -o -x file ]
!
反假為真,反正為假。
[ ! "$a" -gt "$b" ]
>-------------------------------------------------------------------------<
raspberry pi
raspi-config
expand_rootfs
/etc/sysctl.conf
net.ipv6.conf.all.disable_ipv6 = 1
sudo sysctl -p
sudo ifconfig eth0 down && sudo ifconfig eth0 up
ip link set eth0 down
/etc/ssh/sshd_config
#PermitRootLogin without-password
PermitRootLogin yes
apt-get install --no-install-recommends ubuntu-desktop
>-------------------------------------------------------------------------<
bash多開ping
#!/bin/bash
if [ $# -eq 0 ]
then
echo 'need input "ip_list" file'
exit 1
fi
echo Please Check The IP List:
cat $1 | tr -s "\n" > ip_l
cat ip_l > $1
rm ./ip_l
cat $1 | tr -s "\n" | nl
read -r -p "continue? (y/n)" key
if [ "$key" = 'y' ]; then
echo "Start to Run"
else
echo "bye"
exit 1
fi
for i in
seq 1 $(nl $1 | tr -s "\n" | wc -l)
;doecho
sed -n "$i"p $1
Startgnome-terminal -x ping
sed -n "$i"p $1
done
>-------------------------------------------------------------------------<
ubuntu NAT
iptables -A FORWARD -o ens160 -j ACCEPT
iptables -A FORWARD -m state --state ESTABLISHED,RELATED -i ens160 -j ACCEPT
iptables -t nat -A POSTROUTING -o ens160 -j MASQUERADE
route add default gw <gatway ip> eth1
>-------------------------------------------------------------------------<
iperf
ip addr add 10.10.0.1/24 dev eth0
ip addr add 10.10.1.1/24 dev eth1
ip addr add 10.10.2.1/24 dev eth2
ip addr add 10.10.3.1/24 dev eth3
ip link set eth0 up
ip link set eth1 up
ip link set eth2 up
ip link set eth3 up
iperf -s -p 2000 -D
iperf -s -p 2001 -D
iperf -s -p 2002 -D
iperf -s -p 2003 -D
iperf -c 10.10.0.2 -l 64k -w 64k -i 5 -P 10 -p 2000 -t 20 > eth0.txt
iperf -c 10.10.1.2 -l 64k -w 64k -i 5 -P 10 -p 2000 -t 20 > eth1.txt
iperf -c 10.10.2.2 -l 64k -w 64k -i 5 -P 10 -p 2000 -t 20 > eth2.txt
iperf -c 10.10.3.2 -l 64k -w 64k -i 5 -P 10 -p 2000 -t 20 > eth3.txt
ip addr add 10.10.0.2/24 dev eth0
ip addr add 10.10.1.2/24 dev eth1
ip addr add 10.10.2.2/24 dev eth2
ip addr add 10.10.3.2/24 dev eth3
ip link set eth0 up
ip link set eth1 up
ip link set eth2 up
ip link set eth3 up
iperf -s -p 2000 -D
iperf -s -p 2001 -D
iperf -s -p 2002 -D
iperf -s -p 2003 -D
iperf -c 10.10.0.1 -l 64k -w 64k -i 5 -P 10 -p 2000 -t 20 > eth0.txt
iperf -c 10.10.1.1 -l 64k -w 64k -i 5 -P 10 -p 2000 -t 20 > eth1.txt
iperf -c 10.10.2.1 -l 64k -w 64k -i 5 -P 10 -p 2000 -t 20 > eth2.txt
iperf -c 10.10.3.1 -l 64k -w 64k -i 5 -P 10 -p 2000 -t 20 > eth3.txt
ip addr del 10.10.0.2/24 dev eth0
>-------------------------------------------------------------------------<
vmkfstools
vmkfstools -i ./win2016-clean_0-000002.vmdk ./win2016-01.vmdk
>-------------------------------------------------------------------------<
Mellanox driver
Linux SW/Drivers
http://www.mellanox.com/page/products_dyn?product_family=26&mtag=linux_sw_drivers
./mlnxofedinstall
Mellanox Firmware Tools (MFT)
http://www.mellanox.com/page/management_tools
mst start
Mellanox UEFI
http://www.mellanox.com/page/products_dyn?product_family=257&mtag=UEFI
flint -d /dev/mst/mt4117_pciconf0 --allow_rom_change brom ./FlexBoot-RELEASE_0x1015.efirom
flint -d /dev/mst/mt4117_pciconf0 q
http://www.mellanox.com/related-docs/prod_software/Mellanox_PreBoot_Drivers_User_Manual_v2.9.pdf
mlxup
./mlxup -d -i -f
http://www.mellanox.com/page/mlxup_firmware_tool
http://www.mellanox.com/page/firmware_table_ConnectX4LxEN
mst start
mst status
flint -d /dev/mst/mt4117_pciconf0 -i ./fw-ConnectX4Lx-rel-14_20_1010-MCX4411A-ACQ_Ax-FlexBoot-3.5.210.bin --allow_psid_change burn
reboot
flint -d /dev/mst/mt4117_pciconf0 --allow_rom_change brom ./FlexBoot-RELEASE_0x1015.efirom
http://www.mellanox.com/page/firmware_download
>-------------------------------------------------------------------------<
freeradius
apt install freeradius
client ipv6 {
ipv6addr = 2017::/16
secret = 123456
}
client ipv4 {
ipaddr = 192.168.0.0/16
secret = 123456
}
radius_h4 Cleartext-Password := "123456"
Attr-26=0x483D34
radius_h3 Cleartext-Password := "123456"
Attr-26=0x483D33
radius_h2 Cleartext-Password := "123456"
Attr-26=0x483D32
radius_h1 Cleartext-Password := "123456"
Attr-26=0x483D31
radius_h0 Cleartext-Password := "123456"
Attr-26=0x483D30
suttest Cleartext-Password := "Adtest123"
Attr-26=0x483D34
usertest Cleartext-Password := "Password12"
Attr-26=0x483D34
radius_admin: Password: "123456"
Vendor-Specific Attributes: "H=4, I=4"
radius_operator: Password: "654321"
Vendor-Specific Attributes: "H=3, I=3"
radius_user: Password: "654321"
Vendor-Specific Attributes: "H=2, I=2"
radius_callback: Password: "654321"
Vendor-Specific Attributes: "H=1, I=1"
https://www.supermicro.com/support/faqs/faq.cfm?faq=22374
On pages 9 and 10 it gives the following example:
"radius_admin" User-Password == "123456"
Vendor-Specific = "H=4, I=4"
In FreeRadius 2.1.12, it should be:
"radius_admin" Cleartext-Password := "123456"
Vendor-Specific = "H=4, I=4"
HOWEVER, the "Vendor-specific" attribute is no longer supported by the RFC, which is why I was unable to get it to work in FreeRadius 3.0.4.
In FreeRadius >= 3.0.4 it should be:
"radius_admin" Cleartext-Password := "123456"
Attr-26 = 0x483D342C20493D34
(where the 0xblahblah) is the hex-encoding of the "H=4, I=4" string.
others are here:
Callback H=1, I=1 Attr-26 = 0x483D312C20493D31
User H=2, I=2 Attr-26 = 0x483D322C20493D32
Operator H=3, I=3 Attr-26 = 0x483D332C20493D33
Administrator H=4, I=4 Attr-26 = 0x483D342C20493D34
>-------------------------------------------------------------------------<
grub.cfg
set http_prefix="(http,192.168.1.1)"
set default='Reboot'
set timeout=60
if [ $grub_platform == efi ] ;then
set platform="UEFI"
insmod efi_gop
insmod efi_uga
insmod font
else
set platform="BIOS"
fi
menuentry "Exit (BOOT MODE: ${platform} $grub_platform $grub_cpu)" --unrestricted {
exit
}
menuentry "Reboot" --unrestricted {
reboot
}
menuentry 'Ubuntu Server 17.10' {
linux ${http_prefix}/linux
initrd ${http_prefix}/initrd.gz
}
>-------------------------------------------------------------------------<
pxe
option domain-name "sitddns.com";
option domain-name-servers 192.168.16.1;
default-lease-time 600;
max-lease-time 7200;
ddns-update-style interim;
update-static-leases on;
zone sitddns.com. {
primary 192.168.16.1;
}
option space PXE;
option PXE.mtftp-ip code 1 = ip-address;
option PXE.mtftp-cport code 2 = unsigned integer 16;
option PXE.mtftp-sport code 3 = unsigned integer 16;
option PXE.mtftp-tmout code 4 = unsigned integer 8;
option PXE.mtftp-delay code 5 = unsigned integer 8;
option arch code 93 = unsigned integer 16; # RFC4578
subnet 192.168.16.0 netmask 255.255.255.0 {
range 192.168.16.50 192.168.16.100;
option routers 192.168.16.1;
class "pxeclients" {
match if substring (option vendor-class-identifier, 0, 9) = "PXEClient";
next-server 192.168.16.1;
if option arch = 00:00 {
filename "boot/grub/i386-pc/core.0";
} else {
filename "boot/grub/grub.efi";
}
}
}
>-------------------------------------------------------------------------<
Switch port mirror
將0/1的封包導到0/2做monitor
# configure
# port-monitor session 1 source interface 0/1
# port-monitor session 1 destination interface 0/2
enable port-monitor
# port-monitor session 1 mode
check port-monitor status
# do show port-monitor session
disable port-monitor
# no port-monitor session 1 mode
>-------------------------------------------------------------------------<
bash loop
#!/bin/bash
echo "" > running.log
ifconfig > g_ifconfig.txt
main(){
while [:]
do
for j in
seq 1 3
do
echo -ne "$j\r"
sleep 1
done
ifconfig > now_ifconfig.txt
diff now_ifconfig.txt g_ifconfig.txt
if [ $? -ne 0 ]; then
echo "FAIL"
break
else
echo "PASS"
fi
done
}
main 2>&1 | tee -a "running.log"
>-------------------------------------------------------------------------<
robot
CheckAllSensors
${req_dict} Create Dictionary
: FOR ${INDEX} IN RANGE 1 89
\ Log ${INDEX}
\ Click Element xpath=//*[@id="_infoLeft"]/div/table/tbody/tr[${INDEX}]/td[1]
\ Element Text Should Be xpath=//*[@id="_infoLeft"]/div/table/tbody/tr[${INDEX}]/td[1] @{Sensor_List}[${INDEX - 1}]
\ Element Text Should Be xpath=//*[@id="_infoLeft"]/div/table/tbody/tr[${INDEX}]/td[2] @{Sensor_Status}[${INDEX - 1}]
\ ${temp}= Get Text xpath=//*[@id="_lowerC"]
\ Set To Dictionary ${req_dict} @{Sensor_List}[${INDEX - 1}]_lc=${temp}
\ ${temp}= Get Text xpath=//*[@id="_lowerNC"]
\ Set To Dictionary ${req_dict} @{Sensor_List}[${INDEX - 1}]_lnc=${temp}
\ ${temp}= Get Text xpath=//*[@id="_upperC"]
\ Set To Dictionary ${req_dict} @{Sensor_List}[${INDEX - 1}]_uc=${temp}
\ ${temp}= Get Text xpath=//*[@id="_upperNC"]
\ Set To Dictionary ${req_dict} @{Sensor_List}[${INDEX - 1}]_unc=${temp}
Log ${req_dict}
*** Settings ***
Suite Teardown Close All Browsers
Force Tags RM17_Sanity
Resource ../Config_COMMON/VAR_User.robot
Resource ../Config_IPMI/KEY_Common.robot
Resource ../Config_WEB/KEY_Common.robot
Library String
Library json
Library Collections
Library OperatingSystem
Library Selenium2Library
*** Variables ***
@{Sensor_List} HDD0 HDD1 HDD2 HDD3 HDD4 HDD5 HDD6
... HDD7 HDD8 HDD9 HDD10 HDD11 HDD12 HDD13
... HDD14 HDD15 HDD16 HDD17 HDD18 HDD19 HDD20
... HDD21 HDD22 HDD23 Temp_Outlet Service_Status CPU_0 CPU_1
... Temp_CPU0 Temp_CPU1 Temp_DIMM_AB Temp_DIMM_CD Temp_DIMM_EF Temp_DIMM_GH Temp_VR_CPU0
... Temp_VR_CPU1 Temp_VR_DIMM_AB Temp_VR_DIMM_CD Temp_VR_DIMM_EF Temp_VR_DIMM_GH CPU_DIMM_VRHOT DIMM_HOT
... Temp_PCI_Area Temp_PCH Fan_SYS0 Fan_SYS1 Fan_SYS2 Fan_SYS3 Fan_SYS4
... Fan_SYS5 Fan_SYS6 Fan_SYS7 Volt_P3V3 Volt_P5V Volt_P12V Volt_P1V05
... Volt_P1V8_AUX Volt_P3V3_AUX Volt_P5V_AUX Volt_P3V_BAT SYS_NIC1_LinkUp SYS_NIC2_LinkUp Volt_VR_CPU0
... Volt_VR_CPU1 Volt_VR_DIMM_AB Volt_VR_DIMM_CD Volt_VR_DIMM_EF Volt_VR_DIMM_GH PSU1 Status PSU2 Status
... PSU1 Input PSU2 Input PSU Redundancy Event Log Watchdog Power Unit System Event
... BMC_Mem_Free CATERR Temp_PCI_Inlet1 Temp_PCI_Inlet2 Temp_Ambient_FP Button Airflow
... NVMeSSD_0 NVMeSSD_1 Fan_SSD0 Fan_SSD1
@{Sensor_Status} Drive Presence Drive Presence Drive Presence Drive Presence Drive Presence Drive Presence Drive Presence
... Drive Presence Drive Presence Drive Presence Drive Presence Drive Presence Drive Presence Drive Presence
... Drive Presence Drive Presence Drive Presence Drive Presence Drive Presence Drive Presence Drive Presence
... Drive Presence Drive Presence Drive Presence Normal KVM service is running Virtual storage service is running Web service is running Processor Presence Detected Processor Presence Detected
... Normal Normal Normal Normal Normal Normal Normal
... Normal Normal Normal Normal Normal All deasserted All deasserted
... Normal Normal Normal Normal Normal Normal Normal
... Normal Normal Normal Normal Normal Normal Normal
... Normal Normal Normal Normal State Asserted All deasserted Normal
... Normal Normal Normal Normal Normal Presence Detected Presence Detected
... Normal Normal Fully Redundant (Redundancy Regained) Log Area Reset/Cleared All deasserted All deasserted All deasserted
... Normal All deasserted Normal Normal Normal All deasserted Normal
... Normal Normal Normal Normal
&{Sensor_Spec} HDD0_lc=N/A HDD0_lnc=N/A HDD0_uc=N/A HDD0_unc=N/A HDD1_lc=N/A HDD1_lnc=N/A HDD1_uc=N/A
... HDD1_unc=N/A HDD2_lc=N/A HDD2_lnc=N/A HDD2_uc=N/A HDD2_unc=N/A HDD3_lc=N/A HDD3_lnc=N/A
... HDD3_uc=N/A HDD3_unc=N/A HDD4_lc=N/A HDD4_lnc=N/A HDD4_uc=N/A HDD4_unc=N/A HDD5_lc=N/A
... HDD5_lnc=N/A HDD5_uc=N/A HDD5_unc=N/A HDD6_lc=N/A HDD6_lnc=N/A HDD6_uc=N/A HDD6_unc=N/A
... HDD7_lc=N/A HDD7_lnc=N/A HDD7_uc=N/A HDD7_unc=N/A HDD8_lc=N/A HDD8_lnc=N/A HDD8_uc=N/A
... HDD8_unc=N/A HDD9_lc=N/A HDD9_lnc=N/A HDD9_uc=N/A HDD9_unc=N/A HDD10_lc=N/A HDD10_lnc=N/A
... HDD10_uc=N/A HDD10_unc=N/A HDD11_lc=N/A HDD11_lnc=N/A HDD11_uc=N/A HDD11_unc=N/A HDD12_lc=N/A
... HDD12_lnc=N/A HDD12_uc=N/A HDD12_unc=N/A HDD13_lc=N/A HDD13_lnc=N/A HDD13_uc=N/A HDD13_unc=N/A
... HDD14_lc=N/A HDD14_lnc=N/A HDD14_uc=N/A HDD14_unc=N/A HDD15_lc=N/A HDD15_lnc=N/A HDD15_uc=N/A
... HDD15_unc=N/A HDD16_lc=N/A HDD16_lnc=N/A HDD16_uc=N/A HDD16_unc=N/A HDD17_lc=N/A HDD17_lnc=N/A
... HDD17_uc=N/A HDD17_unc=N/A HDD18_lc=N/A HDD18_lnc=N/A HDD18_uc=N/A HDD18_unc=N/A HDD19_lc=N/A
... HDD19_lnc=N/A HDD19_uc=N/A HDD19_unc=N/A HDD20_lc=N/A HDD20_lnc=N/A HDD20_uc=N/A HDD20_unc=N/A
... HDD21_lc=N/A HDD21_lnc=N/A HDD21_uc=N/A HDD21_unc=N/A HDD22_lc=N/A HDD22_lnc=N/A HDD22_uc=N/A
... HDD22_unc=N/A HDD23_lc=N/A HDD23_lnc=N/A HDD23_uc=N/A HDD23_unc=N/A Temp_Outlet_lc=N/A Temp_Outlet_lnc=N/A
... Temp_Outlet_uc=N/A Temp_Outlet_unc=N/A Service_Status_lc=N/A Service_Status_lnc=N/A Service_Status_uc=N/A Service_Status_unc=N/A CPU_0_lc=N/A
... CPU_0_lnc=N/A CPU_0_uc=N/A CPU_0_unc=N/A CPU_1_lc=N/A CPU_1_lnc=N/A CPU_1_uc=N/A CPU_1_unc=N/A
... Temp_CPU0_lc=N/A Temp_CPU0_lnc=N/A Temp_CPU0_uc=100 \u00b0 C Temp_CPU0_unc=99 \u00b0 C Temp_CPU1_lc=N/A Temp_CPU1_lnc=N/A Temp_CPU1_uc=100 \u00b0 C
... Temp_CPU1_unc=99 \u00b0 C Temp_DIMM_AB_lc=N/A Temp_DIMM_AB_lnc=N/A Temp_DIMM_AB_uc=100 \u00b0 C Temp_DIMM_AB_unc=99 \u00b0 C Temp_DIMM_CD_lc=N/A Temp_DIMM_CD_lnc=N/A
... Temp_DIMM_CD_uc=85 \u00b0 C Temp_DIMM_CD_unc=84 \u00b0 C Temp_DIMM_EF_lc=N/A Temp_DIMM_EF_lnc=N/A Temp_DIMM_EF_uc=85 \u00b0 C Temp_DIMM_EF_unc=84 \u00b0 C Temp_DIMM_GH_lc=N/A
... Temp_DIMM_GH_lnc=N/A Temp_DIMM_GH_uc=85 \u00b0 C Temp_DIMM_GH_unc=84 \u00b0 C Temp_VR_CPU0_lc=N/A Temp_VR_CPU0_lnc=N/A Temp_VR_CPU0_uc=85 \u00b0 C Temp_VR_CPU0_unc=84 \u00b0 C
... Temp_VR_CPU1_lc=N/A Temp_VR_CPU1_lnc=N/A Temp_VR_CPU1_uc=105 \u00b0 C Temp_VR_CPU1_unc=104 \u00b0 C Temp_VR_DIMM_AB_lc=N/A Temp_VR_DIMM_AB_lnc=N/A Temp_VR_DIMM_AB_uc=105 \u00b0 C
... Temp_VR_DIMM_AB_unc=104 \u00b0 C Temp_VR_DIMM_CD_lc=N/A Temp_VR_DIMM_CD_lnc=N/A Temp_VR_DIMM_CD_uc=105 \u00b0 C Temp_VR_DIMM_CD_unc=104 \u00b0 C Temp_VR_DIMM_EF_lc=N/A Temp_VR_DIMM_EF_lnc=N/A
... Temp_VR_DIMM_EF_uc=105 \u00b0 C Temp_VR_DIMM_EF_unc=104 \u00b0 C Temp_VR_DIMM_GH_lc=N/A Temp_VR_DIMM_GH_lnc=N/A Temp_VR_DIMM_GH_uc=105 \u00b0 C Temp_VR_DIMM_GH_unc=104 \u00b0 C CPU_DIMM_VRHOT_lc=N/A
... CPU_DIMM_VRHOT_lnc=N/A CPU_DIMM_VRHOT_uc=N/A CPU_DIMM_VRHOT_unc=N/A DIMM_HOT_lc=N/A DIMM_HOT_lnc=N/A DIMM_HOT_uc=N/A DIMM_HOT_unc=N/A
... Temp_PCI_Area_lc=N/A Temp_PCI_Area_lnc=N/A Temp_PCI_Area_uc=80 \u00b0 C Temp_PCI_Area_unc=75 \u00b0 C Temp_PCH_lc=N/A Temp_PCH_lnc=N/A Temp_PCH_uc=100 \u00b0 C
... Temp_PCH_unc=98 \u00b0 C Fan_SYS0_lc=N/A Fan_SYS0_lnc=N/A Fan_SYS0_uc=100 \u00b0 C Fan_SYS0_unc=98 \u00b0 C Fan_SYS1_lc=500 RPM Fan_SYS1_lnc=1000 RPM
... Fan_SYS1_uc=N/A Fan_SYS1_unc=N/A Fan_SYS2_lc=500 RPM Fan_SYS2_lnc=1000 RPM Fan_SYS2_uc=N/A Fan_SYS2_unc=N/A Fan_SYS3_lc=500 RPM
... Fan_SYS3_lnc=1000 RPM Fan_SYS3_uc=N/A Fan_SYS3_unc=N/A Fan_SYS4_lc=500 RPM Fan_SYS4_lnc=1000 RPM Fan_SYS4_uc=N/A Fan_SYS4_unc=N/A
... Fan_SYS5_lc=500 RPM Fan_SYS5_lnc=1000 RPM Fan_SYS5_uc=N/A Fan_SYS5_unc=N/A Fan_SYS6_lc=500 RPM Fan_SYS6_lnc=1000 RPM Fan_SYS6_uc=N/A
... Fan_SYS6_unc=N/A Fan_SYS7_lc=500 RPM Fan_SYS7_lnc=1000 RPM Fan_SYS7_uc=N/A Fan_SYS7_unc=N/A Volt_P3V3_lc=3.132 Volts Volt_P3V3_lnc=N/A
... Volt_P3V3_uc=3.466 Volts Volt_P3V3_unc=N/A Volt_P5V_lc=4.743 Volts Volt_P5V_lnc=N/A Volt_P5V_uc=5.251 Volts Volt_P5V_unc=N/A Volt_P12V_lc=4.743 Volts
... Volt_P12V_lnc=N/A Volt_P12V_uc=5.251 Volts Volt_P12V_unc=N/A Volt_P1V05_lc=0.99 Volts Volt_P1V05_lnc=N/A Volt_P1V05_uc=1.107 Volts Volt_P1V05_unc=N/A
... Volt_P1V8_AUX_lc=0.99 Volts Volt_P1V8_AUX_lnc=N/A Volt_P1V8_AUX_uc=1.107 Volts Volt_P1V8_AUX_unc=N/A Volt_P3V3_AUX_lc=3.132 Volts Volt_P3V3_AUX_lnc=N/A Volt_P3V3_AUX_uc=3.466 Volts
... Volt_P3V3_AUX_unc=N/A Volt_P5V_AUX_lc=4.622 Volts Volt_P5V_AUX_lnc=N/A Volt_P5V_AUX_uc=5.372 Volts Volt_P5V_AUX_unc=N/A Volt_P3V_BAT_lc=4.622 Volts Volt_P3V_BAT_lnc=N/A
... Volt_P3V_BAT_uc=5.372 Volts Volt_P3V_BAT_unc=N/A SYS_NIC1_LinkUp_lc=N/A SYS_NIC1_LinkUp_lnc=N/A SYS_NIC1_LinkUp_uc=N/A SYS_NIC1_LinkUp_unc=N/A SYS_NIC2_LinkUp_lc=N/A
... SYS_NIC2_LinkUp_lnc=N/A SYS_NIC2_LinkUp_uc=N/A SYS_NIC2_LinkUp_unc=N/A Volt_VR_CPU0_lc=1.35 Volts Volt_VR_CPU0_lnc=N/A Volt_VR_CPU0_uc=1.96 Volts Volt_VR_CPU0_unc=N/A
... Volt_VR_CPU1_lc=1.35 Volts Volt_VR_CPU1_lnc=N/A Volt_VR_CPU1_uc=1.96 Volts Volt_VR_CPU1_unc=N/A Volt_VR_DIMM_AB_lc=1.35 Volts Volt_VR_DIMM_AB_lnc=N/A Volt_VR_DIMM_AB_uc=1.96 Volts
... Volt_VR_DIMM_AB_unc=N/A Volt_VR_DIMM_CD_lc=1.08 Volts Volt_VR_DIMM_CD_lnc=N/A Volt_VR_DIMM_CD_uc=1.32 Volts Volt_VR_DIMM_CD_unc=N/A Volt_VR_DIMM_EF_lc=1.08 Volts Volt_VR_DIMM_EF_lnc=N/A
... Volt_VR_DIMM_EF_uc=1.32 Volts Volt_VR_DIMM_EF_unc=N/A Volt_VR_DIMM_GH_lc=1.08 Volts Volt_VR_DIMM_GH_lnc=N/A Volt_VR_DIMM_GH_uc=1.32 Volts Volt_VR_DIMM_GH_unc=N/A PSU1 Status_lc=N/A
... PSU1 Status_lnc=N/A PSU1 Status_uc=N/A PSU1 Status_unc=N/A PSU2 Status_lc=N/A PSU2 Status_lnc=N/A PSU2 Status_uc=N/A PSU2 Status_unc=N/A
... PSU1 Input_lc=0 Watts PSU1 Input_lnc=N/A PSU1 Input_uc=N/A PSU1 Input_unc=N/A PSU2 Input_lc=0 Watts PSU2 Input_lnc=N/A PSU2 Input_uc=N/A
... PSU2 Input_unc=N/A PSU Redundancy_lc=N/A PSU Redundancy_lnc=N/A PSU Redundancy_uc=N/A PSU Redundancy_unc=N/A Event Log_lc=N/A Event Log_lnc=N/A
... Event Log_uc=N/A Event Log_unc=N/A Watchdog_lc=N/A Watchdog_lnc=N/A Watchdog_uc=N/A Watchdog_unc=N/A Power Unit_lc=N/A
... Power Unit_lnc=N/A Power Unit_uc=N/A Power Unit_unc=N/A System Event_lc=N/A System Event_lnc=N/A System Event_uc=N/A System Event_unc=N/A
... BMC_Mem_Free_lc=N/A BMC_Mem_Free_lnc=N/A BMC_Mem_Free_uc=N/A BMC_Mem_Free_unc=N/A CATERR_lc=N/A CATERR_lnc=N/A CATERR_uc=N/A
... CATERR_unc=N/A Temp_PCI_Inlet1_lc=N/A Temp_PCI_Inlet1_lnc=N/A Temp_PCI_Inlet1_uc=80 \u00b0 C Temp_PCI_Inlet1_unc=75 \u00b0 C Temp_PCI_Inlet2_lc=N/A Temp_PCI_Inlet2_lnc=N/A
... Temp_PCI_Inlet2_uc=80 \u00b0 C Temp_PCI_Inlet2_unc=75 \u00b0 C Temp_Ambient_FP_lc=0 \u00b0 C Temp_Ambient_FP_lnc=N/A Temp_Ambient_FP_uc=45 \u00b0 C Temp_Ambient_FP_unc=41 \u00b0 C Button_lc=0 \u00b0 C
... Button_lnc=N/A Button_uc=45 \u00b0 C Button_unc=41 \u00b0 C Airflow_lc=N/A Airflow_lnc=N/A Airflow_uc=N/A Airflow_unc=N/A
... NVMeSSD_0_lc=N/A NVMeSSD_0_lnc=N/A NVMeSSD_0_uc=74 \u00b0 C NVMeSSD_0_unc=73 \u00b0 C NVMeSSD_1_lc=N/A NVMeSSD_1_lnc=N/A NVMeSSD_1_uc=74 \u00b0 C
... NVMeSSD_1_unc=73 \u00b0 C Fan_SSD0_lc=500 RPM Fan_SSD0_lnc=1000 RPM Fan_SSD0_uc=N/A Fan_SSD0_unc=N/A Fan_SSD1_lc=500 RPM Fan_SSD1_lnc=1000 RPM
... Fan_SSD1_uc=N/A Fan_SSD1_unc=N/A
*** Test Cases ***
GetSpec
Run wget -O "S2B_S2Sx BMC FW Spec.rev047.doc" -N "http://192.168.10.147/10606121/test/raw/master/S2B_S2Sx%20BMC%20FW%20Spec.rev047.doc"
Run antiword "S2B_S2Sx BMC FW Spec.rev047.doc" > Spec.txt
${spec_temp} Run cat Spec.txt |grep Temp_DIMM_AB |sed -n '3p'|awk '{print $4 "| "}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} Temp_DIMM_AB_uc=${spec_temp} ° C
${spec_temp} Run cat Spec.txt |grep Temp_DIMM_AB |sed -n '3p'|awk '{print $3 "| "}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} Temp_DIMM_AB_unc=${spec_temp} ° C
${spec_temp} Run cat Spec.txt |grep Temp_DIMM_CD |sed -n '3p'|awk '{print $4 "| "}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} Temp_DIMM_CD_uc=${spec_temp} ° C
${spec_temp} Run cat Spec.txt |grep Temp_DIMM_CD |sed -n '3p'|awk '{print $3 "| "}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} Temp_DIMM_CD_unc=${spec_temp} ° C
${spec_temp} Run cat Spec.txt |grep Temp_DIMM_EF |sed -n '3p'|awk '{print $4 "| "}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} Temp_DIMM_EF_uc=${spec_temp} ° C
${spec_temp} Run cat Spec.txt |grep Temp_DIMM_EF |sed -n '3p'|awk '{print $3 "| "}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} Temp_DIMM_EF_unc=${spec_temp} ° C
${spec_temp} Run cat Spec.txt |grep Temp_DIMM_GH |sed -n '3p'|awk '{print $4 "| "}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} Temp_DIMM_GH_uc=${spec_temp} ° C
${spec_temp} Run cat Spec.txt |grep Temp_DIMM_GH |sed -n '3p'|awk '{print $3 "| "}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} Temp_DIMM_GH_unc=${spec_temp} ° C
${spec_temp} Run cat Spec.txt |grep Temp_VR_CPU0 |sed -n '3p'|awk '{print $4 "| "}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} Temp_VR_CPU0_uc=${spec_temp} ° C
${spec_temp} Run cat Spec.txt |grep Temp_VR_CPU0 |sed -n '3p'|awk '{print $3 "| "}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} Temp_VR_CPU0_unc=${spec_temp} ° C
${spec_temp} Run cat Spec.txt |grep Temp_VR_CPU1 |sed -n '3p'|awk '{print $4 "| "}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} Temp_VR_CPU1_uc=${spec_temp} ° C
${spec_temp} Run cat Spec.txt |grep Temp_VR_CPU1 |sed -n '3p'|awk '{print $3 "| "}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} Temp_VR_CPU1_unc=${spec_temp} ° C
${spec_temp} Run cat Spec.txt |grep Temp_VR_DIMM_AB |sed -n '3p'|awk '{print $4 "| "}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} Temp_VR_DIMM_AB_uc=${spec_temp} ° C
${spec_temp} Run cat Spec.txt |grep Temp_VR_DIMM_AB |sed -n '3p'|awk '{print $3 "| "}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} Temp_VR_DIMM_AB_unc=${spec_temp} ° C
${spec_temp} Run cat Spec.txt |grep Temp_VR_DIMM_CD |sed -n '3p'|awk '{print $4 "| "}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} Temp_VR_DIMM_CD_uc=${spec_temp} ° C
${spec_temp} Run cat Spec.txt |grep Temp_VR_DIMM_CD |sed -n '3p'|awk '{print $3 "| "}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} Temp_VR_DIMM_CD_unc=${spec_temp} ° C
${spec_temp} Run cat Spec.txt |grep Temp_VR_DIMM_EF |sed -n '3p'|awk '{print $4 "| "}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} Temp_VR_DIMM_EF_uc=${spec_temp} ° C
${spec_temp} Run cat Spec.txt |grep Temp_VR_DIMM_EF |sed -n '3p'|awk '{print $3 "| "}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} Temp_VR_DIMM_EF_unc=${spec_temp} ° C
${spec_temp} Run cat Spec.txt |grep Temp_VR_DIMM_GH |sed -n '3p'|awk '{print $4 "| "}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} Temp_VR_DIMM_GH_uc=${spec_temp} ° C
${spec_temp} Run cat Spec.txt |grep Temp_VR_DIMM_GH |sed -n '3p'|awk '{print $3 "| "}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} Temp_VR_DIMM_GH_unc=${spec_temp} ° C
${spec_temp} Run cat Spec.txt |grep Temp_PCI_Area |sed -n '2p'|awk '{print $4 "| "}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} Temp_PCI_Area_uc=${spec_temp} ° C
${spec_temp} Run cat Spec.txt |grep Temp_PCI_Area |sed -n '2p'|awk '{print $3 "| "}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} Temp_PCI_Area_unc=${spec_temp} ° C
${spec_temp} Run cat Spec.txt |grep Temp_PCH |sed -n '2p'|awk '{print $4 "| "}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} Temp_PCH_uc=${spec_temp} ° C
${spec_temp} Run cat Spec.txt |grep Temp_PCH |sed -n '2p'|awk '{print $3 "| "}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} Temp_PCH_unc=${spec_temp} ° C
${spec_temp} Run cat Spec.txt |grep Fan_SYS0 |sed -n '$p'|awk '{print $3 "|"}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} "Fan_SYS0_uc=${spec_temp} RPM
${spec_temp} Run cat Spec.txt |grep Fan_SYS0 |sed -n '$p'|awk '{print $5 "|"}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} "Fan_SYS0_unc=${spec_temp} RPM
${spec_temp} Run cat Spec.txt |grep Fan_SYS1 |sed -n '$p'|awk '{print $3 "|"}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} "Fan_SYS1_uc=${spec_temp} RPM
${spec_temp} Run cat Spec.txt |grep Fan_SYS1 |sed -n '$p'|awk '{print $5 "|"}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} "Fan_SYS1_unc=${spec_temp} RPM
${spec_temp} Run cat Spec.txt |grep Fan_SYS2 |sed -n '$p'|awk '{print $3 "|"}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} "Fan_SYS2_uc=${spec_temp} RPM
${spec_temp} Run cat Spec.txt |grep Fan_SYS2 |sed -n '$p'|awk '{print $5 "|"}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} "Fan_SYS2_unc=${spec_temp} RPM
${spec_temp} Run cat Spec.txt |grep Fan_SYS3 |sed -n '$p'|awk '{print $3 "|"}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} "Fan_SYS3_uc=${spec_temp} RPM
${spec_temp} Run cat Spec.txt |grep Fan_SYS3 |sed -n '$p'|awk '{print $5 "|"}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} "Fan_SYS3_unc=${spec_temp} RPM
${spec_temp} Run cat Spec.txt |grep Fan_SYS4 |sed -n '$p'|awk '{print $3 "|"}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} "Fan_SYS4_uc=${spec_temp} RPM
${spec_temp} Run cat Spec.txt |grep Fan_SYS4 |sed -n '$p'|awk '{print $5 "|"}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} "Fan_SYS4_unc=${spec_temp} RPM
${spec_temp} Run cat Spec.txt |grep Fan_SYS5 |sed -n '$p'|awk '{print $3 "|"}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} "Fan_SYS5_uc=${spec_temp} RPM
${spec_temp} Run cat Spec.txt |grep Fan_SYS5 |sed -n '$p'|awk '{print $5 "|"}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} "Fan_SYS5_unc=${spec_temp} RPM
${spec_temp} Run cat Spec.txt |grep Fan_SYS6 |sed -n '$p'|awk '{print $3 "|"}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} "Fan_SYS6_uc=${spec_temp} RPM
${spec_temp} Run cat Spec.txt |grep Fan_SYS6 |sed -n '$p'|awk '{print $5 "|"}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} "Fan_SYS6_unc=${spec_temp} RPM
${spec_temp} Run cat Spec.txt |grep Fan_SYS7 |sed -n '$p'|awk '{print $3 "|"}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} "Fan_SYS7_uc=${spec_temp} RPM
${spec_temp} Run cat Spec.txt |grep Fan_SYS7 |sed -n '$p'|awk '{print $5 "|"}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} "Fan_SYS7_unc=${spec_temp} RPM
${spec_temp} Run cat Spec.txt |grep Volt_P3V3 |sed -n '3p'|awk '{print $3 "|"}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} Volt_P3V3_lc=${spec_temp} Volts
${spec_temp} Run cat Spec.txt |grep Volt_P3V3 |sed -n '3p'|awk '{print $4 "|"}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} Volt_P3V3_uc=${spec_temp} Volts
${spec_temp} Run cat Spec.txt |grep Volt_P5V |sed -n '3p'|awk '{print $3 "|"}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} Volt_P5V_lc=${spec_temp} Volts
${spec_temp} Run cat Spec.txt |grep Volt_P5V |sed -n '3p'|awk '{print $4 "|"}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} Volt_P5V_uc=${spec_temp} Volts
${spec_temp} Run cat Spec.txt |grep Volt_P12V |sed -n '$p'|awk '{print $3 "|"}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} Volt_P12V_lc=${spec_temp} Volts
${spec_temp} Run cat Spec.txt |grep Volt_P12V |sed -n '$p'|awk '{print $4 "|"}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} Volt_P12V_uc=${spec_temp} Volts
${spec_temp} Run cat Spec.txt |grep Volt_P1V05 |sed -n '3p'|awk '{print $3 "|"}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} Volt_P1V05_lc=${spec_temp} Volts
${spec_temp} Run cat Spec.txt |grep Volt_P1V05 |sed -n '3p'|awk '{print $4 "|"}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} Volt_P1V05_uc=${spec_temp} Volts
${spec_temp} Run cat Spec.txt |grep Volt_P1V8_AUX |sed -n '$p'|awk '{print $3 "|"}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} Volt_P1V8_AUX_lc=${spec_temp} Volts
${spec_temp} Run cat Spec.txt |grep Volt_P1V8_AUX |sed -n '$p'|awk '{print $4 "|"}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} Volt_P1V8_AUX_uc=${spec_temp} Volts
${spec_temp} Run cat Spec.txt |grep Volt_P3V3_AUX |sed -n '$p'|awk '{print $3 "|"}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} Volt_P3V3_AUX_lc=${spec_temp} Volts
${spec_temp} Run cat Spec.txt |grep Volt_P3V3_AUX |sed -n '$p'|awk '{print $4 "|"}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} Volt_P3V3_AUX_uc=${spec_temp} Volts
${spec_temp} Run cat Spec.txt |grep Volt_P5V_AUX |sed -n '$p'|awk '{print $3 "|"}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} Volt_P5V_AUX_lc=${spec_temp} Volts
${spec_temp} Run cat Spec.txt |grep Volt_P5V_AUX |sed -n '$p'|awk '{print $4 "|"}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} Volt_P5V_AUX_uc=${spec_temp} Volts
${spec_temp} Run cat Spec.txt |grep Volt_P3V_BAT |sed -n '$p'|awk '{print $3 "|"}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} Volt_P3V_BAT_lc=${spec_temp} Volts
${spec_temp} Run cat Spec.txt |grep Volt_P3V_BAT |sed -n '$p'|awk '{print $4 "|"}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} Volt_P3V_BAT_uc=${spec_temp} Volts
${spec_temp} Run cat Spec.txt |grep Volt_VR_CPU0 |sed -n '$p'|awk '{print $3 "|"}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} Volt_VR_CPU0_lc=${spec_temp} Volts
${spec_temp} Run cat Spec.txt |grep Volt_VR_CPU0 |sed -n '$p'|awk '{print $4 "|"}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} Volt_VR_CPU0_uc=${spec_temp} Volts
${spec_temp} Run cat Spec.txt |grep Volt_VR_CPU1 |sed -n '$p'|awk '{print $3 "|"}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} Volt_VR_CPU1_lc=${spec_temp} Volts
${spec_temp} Run cat Spec.txt |grep Volt_VR_CPU1 |sed -n '$p'|awk '{print $4 "|"}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} Volt_VR_CPU1_uc=${spec_temp} Volts
${spec_temp} Run cat Spec.txt |grep Volt_VR_DIMM_AB |sed -n '$p'|awk '{print $3 "|"}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} Volt_VR_DIMM_AB_lc=${spec_temp} Volts
${spec_temp} Run cat Spec.txt |grep Volt_VR_DIMM_AB |sed -n '$p'|awk '{print $4 "|"}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} Volt_VR_DIMM_AB_uc=${spec_temp} Volts
${spec_temp} Run cat Spec.txt |grep Volt_VR_DIMM_CD |sed -n '$p'|awk '{print $3 "|"}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} Volt_VR_DIMM_CD_lc=${spec_temp} Volts
${spec_temp} Run cat Spec.txt |grep Volt_VR_DIMM_CD |sed -n '$p'|awk '{print $4 "|"}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} Volt_VR_DIMM_CD_uc=${spec_temp} Volts
${spec_temp} Run cat Spec.txt |grep Volt_VR_DIMM_EF |sed -n '$p'|awk '{print $3 "|"}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} Volt_VR_DIMM_EF_lc=${spec_temp} Volts
${spec_temp} Run cat Spec.txt |grep Volt_VR_DIMM_EF |sed -n '$p'|awk '{print $4 "|"}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} Volt_VR_DIMM_EF_uc=${spec_temp} Volts
${spec_temp} Run cat Spec.txt |grep Volt_VR_DIMM_GH |sed -n '$p'|awk '{print $3 "|"}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} Volt_VR_DIMM_GH_lc=${spec_temp} Volts
${spec_temp} Run cat Spec.txt |grep Volt_VR_DIMM_GH |sed -n '$p'|awk '{print $4 "|"}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} Volt_VR_DIMM_GH_uc=${spec_temp} Volts
${spec_temp} Run cat Spec.txt |grep "PSU1 Input" |sed -n '2p'|awk '{print $4 "|"}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} "PSU1 Input"_lc=${spec_temp} Watts
${spec_temp} Run cat Spec.txt |grep "PSU2 Input" |sed -n '2p'|awk '{print $4 "|"}'| tr -d "|"" "
Set To Dictionary ${Sensor_Spec} "PSU2 Input"_lc=${spec_temp} Watts
${spec_temp} Run cat Spec.txt |grep "NVMeSSD_0" |sed -n '2p'|awk '{print $5 "|"}'| tr -d "|"" ""[3]"
Set To Dictionary ${Sensor_Spec} "NVMeSSD_0"_uc=${spec_temp} Watts
${spec_temp} Run cat Spec.txt |grep "NVMeSSD_0" |sed -n '2p'|awk '{print $7 "|"}'| tr -d "|"" ""[3]"
Set To Dictionary ${Sensor_Spec} "NVMeSSD_0"_unc=${spec_temp} Watts
${spec_temp} Run cat Spec.txt |grep "NVMeSSD_1" |sed -n '2p'|awk '{print $5 "|"}'| tr -d "|"" ""[3]"
Set To Dictionary ${Sensor_Spec} "NVMeSSD_1"_uc=${spec_temp} Watts
${spec_temp} Run cat Spec.txt |grep "NVMeSSD_1" |sed -n '2p'|awk '{print $7 "|"}'| tr -d "|"" ""[3]"
Set To Dictionary ${Sensor_Spec} "NVMeSSD_1"_unc=${spec_temp} Watts
LoginBMCWebUIWOProfile
KEY OpenBrowserWOProfile
KEY LoginBMCWebUI
GoToSensorReadingsPage
Wait Until Element Is Visible xpath=//*[@id="LN_SERVER_HEALTH"] 30
Click Element xpath=//*[@id="LN_SERVER_HEALTH"]
Wait Until Element Is Visible xpath=/html/body/div[3]/a[1] 30
Click Element xpath=/html/body/div[3]/a[1]
Select Frame xpath=//*[@id="pageFrame"]
Wait Until Element Is Visible xpath=//*[@id="_infoLeft"]/div/table/tbody/tr[1]/td[1] 30
GoToAllSensors
Click Element xpath=//*[@id="_sensorType"]
Click Element xpath=//*[@id="_sensorType"]/option[1]
Wait Until Element Is Visible xpath=//*[@id="_infoLeft"]/div/table/tbody/tr[1]/td[1] 30
CheckAllSensors
${req_dict} Create Dictionary
: FOR ${INDEX} IN RANGE 1 89
\ Log ${INDEX}
\ Click Element xpath=//*[@id="_infoLeft"]/div/table/tbody/tr[${INDEX}]/td[1]
\ Sleep 0.5
\ Run Keyword And Continue On Failure Element Text Should Be xpath=//*[@id="_infoLeft"]/div/table/tbody/tr[${INDEX}]/td[1] @{Sensor_List}[${INDEX - 1}]
\ Run Keyword And Continue On Failure Element Text Should Be xpath=//*[@id="_infoLeft"]/div/table/tbody/tr[${INDEX}]/td[2] @{Sensor_Status}[${INDEX - 1}]
\ Set Suite Variable ${temp} @{Sensor_List}[${INDEX - 1}]_lc
\ Run Keyword And Continue On Failure Element Text Should Be xpath=//*[@id="_lowerC"] &{Sensor_Spec}[${temp}]
\ Set Suite Variable ${temp} @{Sensor_List}[${INDEX - 1}]_lnc
\ Run Keyword And Continue On Failure Element Text Should Be xpath=//*[@id="_lowerNC"] &{Sensor_Spec}[${temp}]
\ Set Suite Variable ${temp} @{Sensor_List}[${INDEX - 1}]_uc
\ Run Keyword And Continue On Failure Element Text Should Be xpath=//*[@id="_upperC"] &{Sensor_Spec}[${temp}]
\ Set Suite Variable ${temp} @{Sensor_List}[${INDEX - 1}]_unc
\ Run Keyword And Continue On Failure Element Text Should Be xpath=//*[@id="_upperNC"] &{Sensor_Spec}[${temp}]
LogoutBMCWebUI
KEY LogoutBMCWebUI
>-------------------------------------------------------------------------<
Robot Framework Windows
https://www.python.org/downloads/
https://pip.pypa.io/en/stable/installing/
python -m pip install --upgrade robotframework
python -m robot --version
python -m pip install robotframework-selenium2library
python -m pip install -U wxPython
python -m pip install robotframework-ride
https://sourceforge.net/projects/wxpython/files/wxPython/2.8.12.1/
ride.py
>-------------------------------------------------------------------------<
awk tr
ipmitool lan print |grep "MAC Address"|awk -F "MAC Address : " '{print $2}'|tr -d ":"
>-------------------------------------------------------------------------<
SMTP SSL
openssl genrsa -out key.pem 2048
openssl req -new -key key.pem -out request.csr
openssl x509 -req -days 3650 -in request.csr -signkey key.pem -out certificate.pem
https://slproweb.com/products/Win32OpenSSL.html
key.pem
-----BEGIN RSA PRIVATE KEY-----
MIIEpAIBAAKCAQEA32axZAz0Cw9T8nx4Dn0GYSH3Vm/h9leVZxrMPCWlae1pfglQ
V9R6ELcd759Xpfjw5EZPX+yUCA6qeTK/pWPAvHCwePxTO280xwz/rm/pdNl18rMU
4nAnogZ8n6MKugUvmPghS8yYWcRR1MduUAul+tfpg+D0NoSYyTVm5mSftA+gNErW
JIq1eXt+cWgDeSXGQGw7KHLYsQ6HPzwx9869KNi8dFcLbLWio9MxsXx+U9Yyo3LS
gJEircZrWmQaMR0hCkVUcbznukYbcHDcmLuy0ZT4YH6OG82Mcx7WOyYGbz5F/We7
zCPLqist2zJj883KOCH4caGuKck7bDVzLJk32wIDAQABAoIBAQDHM8Td2AcMjaBn
SsGq+aTkm+r2slEk3jgkderDfzYeXEqCzj9L8fTeTspszwLSxkXW5zMD7+qXvKwZ
4jytd2N3JGzXlPeKucCv9VFP9A6R2Q6pWTI4L5XHjk0186Yu9UzZ8/eMpWT8NmhZ
eXNOAPUB1eEtbTuWGWo7kFiu++7EGLd989wpRxFsJMZmVUBVK0cG4CFP3jSYTz4h
z+9TtpMiuXL5ObfsBnapQxPoTAvaJNrrUnFnnCrP3A1J9tVw9iiIfrYGok427sXY
ZHrSmEMGkY/eACXxW94XjDOOuHkIETlNiqabkJYfONO3csyG5N0ls0QMrIGjKjB+
hRwV3BzBAoGBAP763sC5YHIPcYUlQWG6ZXkmuNJZCFHX4UuRkqDELMo6XCHC/ws0
ShHkYbSTOFOn/u7OEw+c7lhsFyJ3Sn8KPlIfqLej1ktRvbe/CzsgGv0fpYxmgWiO
DSDCGAJpbVlWaGsHfOnWgFeZQWuka8Q/sgyiH7IWHb4ucYUA2xZrpbDrAoGBAOBL
e3ob0Pa/GA9PYGtTemAaboR80Md/IuJKKtiDL89oNyLi178Cn5Q38vW9Tcb94Taa
XCO/GkbIVdEZ0sXG7P7G+T6oLDU+9JtrVJobXc8m8QOzMk1wGFXO26exUk8MrqIY
ezUugy18IZmPTI0RwMv8vlcBI405eHtWhSIHyVjRAoGAbkucoadOpegyRdMIxjp3
/IEYf70NkUGd7i9pSuuxKEU4Z05PPsx+oeC1twPb4KwR5cD0k9NhcpRHKZyKeAu5
S5LwS4eugeQ4+cvFEu1fX1EaLnKE1fJkkWAEPL7YE0YCYxHZIdmsqLfdia+VAk4/
OaHDrihM82BpsIvfOYKVKMMCgYEAxFnP8om/WQLY8S4v3kTp8I+zCFCsBLkLtMXw
1DGj/RHikqu66wBE6uA/1VivafB+4+ollzWIr0ZZuf+9QF5wwmk1cOCQMty2Dgjb
uz0R1nLksrSA6MGkzBmWuSrGP2V+y3BbC6d4Nq1gTKnh/ez4tpq/ljLtCIizLGYF
jlD6tsECgYAgd2FxPBkGgpb3dvpILnFyyjYWfDnyXfg03BbzqM667DOYkJM5lt8r
sIeT9WFqvlBraJu84xQV9hK4sNeljf/9oPgMqyw1nQbmIecXp3qYd9sDaDmI4CUo
VQYyAyGvASYdPRy+kMYnIcET0PB28CeSqVVJ2HuJLS+cEQq4eo9NVw==
-----END RSA PRIVATE KEY-----
certificate.pem
-----BEGIN CERTIFICATE-----
MIIDZjCCAk4CCQDLFafK8E1JIDANBgkqhkiG9w0BAQsFADB1MQswCQYDVQQGEwJU
VzELMAkGA1UECAwCVFcxCzAJBgNVBAcMAlRXMRAwDgYDVQQKDAdzaXQuY29tMQsw
CQYDVQQLDAJUVzEQMA4GA1UEAwwHc2l0LmNvbTEbMBkGCSqGSIb3DQEJARYMcm9v
dEBzaXQuY29tMB4XDTE4MDQwOTAyMDExOVoXDTI4MDQwNjAyMDExOVowdTELMAkG
A1UEBhMCVFcxCzAJBgNVBAgMAlRXMQswCQYDVQQHDAJUVzEQMA4GA1UECgwHc2l0
LmNvbTELMAkGA1UECwwCVFcxEDAOBgNVBAMMB3NpdC5jb20xGzAZBgkqhkiG9w0B
CQEWDHJvb3RAc2l0LmNvbTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEB
AN9msWQM9AsPU/J8eA59BmEh91Zv4fZXlWcazDwlpWntaX4JUFfUehC3He+fV6X4
8ORGT1/slAgOqnkyv6VjwLxwsHj8UztvNMcM/65v6XTZdfKzFOJwJ6IGfJ+jCroF
L5j4IUvMmFnEUdTHblALpfrX6YPg9DaEmMk1ZuZkn7QPoDRK1iSKtXl7fnFoA3kl
xkBsOyhy2LEOhz88MffOvSjYvHRXC2y1oqPTMbF8flPWMqNy0oCRIq3Ga1pkGjEd
IQpFVHG857pGG3Bw3Ji7stGU+GB+jhvNjHMe1jsmBm8+Rf1nu8wjy6orLdsyY/PN
yjgh+HGhrinJO2w1cyyZN9sCAwEAATANBgkqhkiG9w0BAQsFAAOCAQEAOOueLDMl
XaCzlNQi+VLCVPY6tZU1E1d2ZVCnuA18jtbajOsCE77VaSVqpHqKelmiFJNF4PqR
ukEZRQPTgRah71fwZ41pgR+l6Qj41aBJ2ekZzX46xMqfXy0pBUjkvFQ1gBVayglK
adG0YNIySIECIBenB/ck095PeAcVuKxj13MXdPdMIUODdc/jL5HiWJBIogCS6kI2
RO54KOH44cW0q2viMhyY8Tn496nifiNBmoGlDRqwojn3JTIFv2cpmLZu5RE+8Nd4
wyrOC3/8R8NKZF42HMUtA1Osh80LIPrU3WwlofiuudzWjsn4rq7kA5T5sZij3YsI
Juo3P2jxBg8mTA==
-----END CERTIFICATE-----
>-------------------------------------------------------------------------<
Red Hat yum
cat << EOF > /etc/yum.repos.d/123.repo
[base]
name=CentOS-Base
baseurl=http://ftp.stu.edu.tw/Linux/CentOS/7/os/x86_64
gpgcheck=0
[updates]
name=CentOS-Updates
baseurl=http://ftp.stu.edu.tw/Linux/CentOS/7/updates/x86_64
gpgcheck=0
[extras]
name=CentOS-Extras
baseurl=http://ftp.stu.edu.tw/Linux/CentOS/7/extras/x86_64
gpgcheck=0
[centosplus]
name=CentOS-Plus
baseurl=http://ftp.stu.edu.tw/Linux/CentOS/7/centosplus/x86_64
gpgcheck=0
enabled=0
EOF
cat << EOF > /etc/yum.repos.d/google-x86_64.repo
[google64]
name=Google - x86_64
baseurl=http://dl.google.com/linux/rpm/stable/x86_64
enabled=1
gpgcheck=1
gpgkey=https://dl-ssl.google.com/linux/linux_signing_key.pub
EOF
yum --enablerepo=extras install epel-release -y
yum install -y google-chrome-stable
google-chrome-stable --no-sandbox
echo -e "[daemon]\nAutomaticLoginEnable=True\nAutomaticLogin=root" > /etc/gdm/custom.conf
virsh net-destroy default
vim /etc/gdm/custom.conf
[daemon]
AutomaticLoginEnable=True
AutomaticLogin=root
virsh net-list
virsh net-destroy default
virsh net-undefine default
service libvirtd restart
>-------------------------------------------------------------------------<
DISPLAY
ps e | grep -Po " DISPLAY=[\.0-9A-Za-z:]* " | sort -u
DISPLAY=:0 firefox
export DISPLAY=:1
Xvfb :1 -screen 0 1024x768x16 &
pkill -9 -u
id -u tester
>-------------------------------------------------------------------------<
test
#!/bin/bash
rm -rf ./log;
mkdir ./log;
bmc_up_time="180"
bmc_list=$1
ipmitool user list 1 > userlist1.txt;
main(){
for i in
seq 1 $(nl $bmc_list | tr -s "\n" | wc -l)
do
date
sh=
sed -n "$i"p $bmc_list | awk -F ',' '{print $1}'
echo $sh
ver=
sed -n "$i"p $bmc_list | awk -F ',' '{print $2}'
echo $ver
./Yafuflash2 -vyes -pc -cd $sh
if [ $? -eq 0 ]; then
echo "Yafuflash2 PASS";
else
echo "Yafuflash2 FAIL";
exit 1
fi
echo "Wait BMC up ($bmc_up_time seconds)";
for j in
seq 1 $bmc_up_time
do
echo -ne "$j\r";
sleep 1;
done
echo -ne '\n'
echo "Start to check sdr,mc info,Firmware Revision,user list 1"
mkdir ./log/$i
sdrpass="0"
mcinfopass="0"
verpass="0"
userpass="0"
k="0"
while [ $k -lt 5 ]
do
ipmitool sdr | awk -F"|" '{print $1 $3}' > ./log/$i/sdr.txt;
ipmitool mc info > ./log/$i/mcinfo.txt;
ipmitool user list 1 > ./log/$i/userlist1.txt;
sdrnl=
nl ./log/$i/sdr.txt | tr -s "\n" | wc -l
if [ "$sdrnl" -gt 5 ]; then
echo "sdr check PASS";
let "sdrpass=1";
else
echo "Check Failed on sdr";
fi
mcinfonl=
nl ./log/$i/mcinfo.txt | tr -s "\n" | wc -l
if [ "$mcinfonl" -gt 5 ]; then
echo "mc_info check PASS";
let "mcinfopass=1";
else
echo "Check Failed on mc_info";
fi
vernl=
sed -n 3p ./log/$i/mcinfo.txt | grep "Firmware Revision" | awk -F ': ' '{print $2}'
if [ "$vernl" == "$ver" ]; then
echo "Firmware_Revision PASS";
let "verpass=1";
else
echo "Check Failed on Firmware_Revision";
fi
diff ./userlist1.txt ./log/$i/userlist1.txt
if [ $? -eq 0 ]; then
echo "user list PASS";
let "userpass=1";
else
echo "user list FAIL";
fi
if [ "$sdrpass" == "1" ] && [ "$mcinfopass" == "1" ] && [ "$verpass" == "1" ] && [ "$userpass" == "1" ]; then
echo "LOOP $i PASS";
break
fi
let "k++";
echo "Wail 3 seconds to recheck";
for j in
seq 1 3
do
echo -ne "$j\r";
sleep 1
done
echo -ne '\n';
echo "recheck $k times";
done
if [ "$sdrpass" != "1" ] || [ "$mcinfopass" != "1" ] || [ "$verpass" != "1" ] || [ "$userpass" != "1" ]; then
echo "LOOP $i FAIL";
exit 1
fi
done
}
main 2>&1 | tee -a "running.log"
var fs = require('fs');
var http = require('http');
var https = require('https');
var express = require('express');
var bodyParser = require('body-parser');
var app = express();
var privateKey = fs.readFileSync('key.pem', 'utf8');
var certificate = fs.readFileSync('cert.pem', 'utf8');
var credentials = { key: privateKey, cert: certificate, passphrase: '123456' };
var a=1;
app.get('/email', function (req, res) {
var ip = req.headers['x-forwarded-for'] || req.connection.remoteAddress;
console.log(ip);
if (a > 9) {
a=0;
}
console.log(a);
res.end(a.toString());
a++;
});
app.use(bodyParser.urlencoded({ extended: false }));
app.use(bodyParser.json());
app.post('/', function (req, res) {
console.log(JSON.stringify(req.body));
res.end("OK");
});
var httpServer = http.createServer(app);
var httpsServer = https.createServer(credentials, app);
httpServer.listen(80);
httpsServer.listen(443);
>-------------------------------------------------------------------------<
robot py
from robot.libraries.BuiltIn import BuiltIn
from robot.output import librarylogger
from robot.libraries.OperatingSystem import OperatingSystem
EXECDIR = BuiltIn().get_variable_value("${EXECDIR}")
listdir = OperatingSystem().list_directory(EXECDIR,'Config*',False)
for x in listdir:
librarylogger.write(x, 'INFO', False)
listfile = OperatingSystem().list_directory(EXECDIR+"/"+x,'*.robot',False)
for y in listfile:
librarylogger.write(EXECDIR+"/"+x+"/"+y, 'INFO', False)
BuiltIn().import_resource(EXECDIR+"/"+x+"/"+y)
def log_hello(self):
logger.console('hello')
https://stackoverflow.com/questions/...ables-from-python-library-code
>-------------------------------------------------------------------------<
Notepad++
(?s)\A(?!.*?(?<!\w)(KEY_ALL.robot)(?!\w)).*
(?s)\A((?!Use API site scope).)+\z
https://notepad-plus-plus.org/commun...that-do-not-contain-some-words
http://jeffery062.blogspot.com/2013/02/notepad-regular-expression.html
>-------------------------------------------------------------------------<
XPath Reference
ancestor
ancestor-or-self
attribute
child
descendant
descendant-or-self
following
following-sibling
parent
preceding
preceding-sibling
self
https://developer.mozilla.org/zh-CN/docs/Web/XPath/Axes
>-------------------------------------------------------------------------<
ubuntu
vim /etc/ssh/sshd_config
PermitRootLogin yes
service ssh restart
--------------------------------------------------
chmod 777 /etc/sudoers
vim /etc/sudoers
%sudo ALL=(ALL:ALL) NOPASSWD:ALL
chmod 440 /etc/sudoers
--------------------------------------------------
ubuntu disable ipv6
net.ipv6.conf.all.disable_ipv6 = 1
net.ipv6.conf.default.disable_ipv6 = 1
net.ipv6.conf.lo.disable_ipv6 = 1
sysctl -p
--------------------------------------------------
apt install python
apt install python-pip
apt install libsdl1.2-dev
pip install pypubsub
pip install robotframework
pip install robotframework-ride==1.7.4a1
pip install -U \
-f https://extras.wxpython.org/wxPython4/extras/linux/gtk3/ubuntu-18.04 \
wxPython
--------------------------------------------------
git 永久記憶帳密
git config --global credential.helper store
--------------------------------------------------
a=0;
for (i=2;i<1000;i++){
for (j=2,k=0;j<i;j++){
if (i%j === 0){
k=1;
break;
}
}
if (k === 0) {
a++;
console.log(i);
}
}
console.log(a);
>-------------------------------------------------------------------------<
docker
#Dockerfile
FROM alpine
RUN apk --no-cache add tzdata
RUN apk --no-cache add net-snmp
RUN cp /usr/share/zoneinfo/Asia/Taipei /etc/localtime
RUN echo 'disableAuthorization yes' > /etc/snmp/snmptrapd.conf
VOLUME ["/etc/snmp/","/var/lib/net-snmp/","/root","/tmp"]
EXPOSE 162
CMD ["snmptrapd","-Lf","/tmp/snmptrap.txt","-f","-n","-t","-On","-C","-c","/etc/snmp/snmptrapd.conf","0.0.0.0","::"]
---------------------------------------------------------------------------
docker build -t snmptrapd .
docker container ls
docker container stop trap1
brctl show
docker stop $(docker ps -aq)
docker rm $(docker ps -aq)
docker rmi $(docker images -q)
docker attach trap1
docker exec -it trap1 sh
docker network create -d macvlan --subnet=192.168.210.0/25 --gateway=192.168.210.126 --ipv6 --subnet=2017:401::0/32 --gateway=2017:401::254 -o parent=ens160 mynet
docker run --net=mynet --ip=192.168.210.1 --ip6=2017:401::1 -itd --rm -p 162:162/udp -v /tmp/snmptrapd1:/tmp -v /etc/snmp:/etc/snmp --name snmptrapd1 snmptrapd
docker run --net=mynet --ip=192.168.210.2 --ip6=2017:401::2 -itd --rm -p 162:162/udp -v /tmp/snmptrapd2:/tmp -v /etc/snmp:/etc/snmp --name snmptrapd2 snmptrapd
docker run --net=mynet --ip=192.168.210.3 --ip6=2017:401::3 -itd --rm -p 162:162/udp -v /tmp/snmptrapd3:/tmp -v /etc/snmp:/etc/snmp --name snmptrapd3 snmptrapd
docker run --net=mynet --ip=192.168.210.4 --ip6=2017:401::4 -itd --rm -p 162:162/udp -v /tmp/snmptrapd4:/tmp -v /etc/snmp:/etc/snmp --name snmptrapd4 snmptrapd
docker run --net=mynet --ip=192.168.210.5 --ip6=2017:401::5 -itd --rm -p 162:162/udp -v /tmp/snmptrapd5:/tmp -v /etc/snmp:/etc/snmp --name snmptrapd5 snmptrapd
docker run --net=mynet --ip=192.168.210.6 --ip6=2017:401::6 -itd --rm -p 162:162/udp -v /tmp/snmptrapd6:/tmp -v /etc/snmp:/etc/snmp --name snmptrapd6 snmptrapd
docker run --net=mynet --ip=192.168.210.7 --ip6=2017:401::7 -itd --rm -p 162:162/udp -v /tmp/snmptrapd7:/tmp -v /etc/snmp:/etc/snmp --name snmptrapd7 snmptrapd
docker run --net=mynet --ip=192.168.210.8 --ip6=2017:401::8 -itd --rm -p 162:162/udp -v /tmp/snmptrapd8:/tmp -v /etc/snmp:/etc/snmp --name snmptrapd8 snmptrapd
docker run --net=mynet --ip=192.168.210.9 --ip6=2017:401::9 -itd --rm -p 162:162/udp -v /tmp/snmptrapd9:/tmp -v /etc/snmp:/etc/snmp --name snmptrapd9 snmptrapd
docker exec -it trap1 sh
docker container inspect trap1
>-------------------------------------------------------------------------<
node-fetch
const fetch = require('node-fetch');
var lastid = "";
var title_list = [];
var id_list = [];
var output = "";
dofetch('https://www.dcard.tw/_api/forums/whysoserious/posts?popular=false&limit=100')
function dofetch(url) {
fetch(url)
.then(res => res.json())
.then(function (json) {
dofilter(json)
})
}
function dofilter(res) {
lastid = res[99].id
let res_f = res.filter(res => res.school == "中國文化大學" && res.department == "法律學系");
for (var i = 0; i < res_f.length; ++i) {
title_list.push(res_f[i].title);
id_list.push(res_f[i].id);
}
if (title_list.length < 3) {
console.log(lastid)
console.log(title_list.length)
dofetch('https://www.dcard.tw/_api/forums/whysoserious/posts?popular=false&limit=100' + '&before=' + lastid)
} else {
for (var i = 0; i < title_list.length; ++i) {
output = output + title_list[i];
output = output + "\r\n";
output = output + "https://www.dcard.tw/f/whysoserious/p/" + id_list[i];
output = output + "\r\n";
}
console.log(output)
}
}
>-------------------------------------------------------------------------<
radvd netplan nsupdate
vim /etc/radvd.conf
interface ens160
{
AdvSendAdvert on;
prefix 2018:1:1:1::/64
{
AdvOnLink on;
AdvAutonomous on;
AdvRouterAddr off;
};
};
service radvd restart
service radvd status
systemctl enable radvd
vim /etc/netplan/50-cloud-init.yaml
network:
version: 2
ethernets:
ens160:
accept-ra: no
addresses:
- 192.168.16.1/24
- 2018:1:1:1::1/64
gateway4: 193.168.16.254
gateway6: 2018:1:1:1::1
match:
macaddress: 00:0c:29:9f:c0:95
set-name: ens160
nameservers:
addresses: [8.8.8.8]
vim /etc/bind/named.conf.default-zones
zone "sitddns.com" {
type master;
file "/etc/bind/db.sitddns";
allow-transfer {any;};
allow-query {any;};
allow-update {any;};
check-names ignore;
};
vim /etc/apparmor.d/usr.sbin.named
/etc/bind/** rw,
chmod -R 777 /etc/bind
vim /etc/bind/db.sitddns
$TTL 3600
@ IN SOA ns1.sitddns.com. root.sitddns.com. (
190710 ; Serial
3600 ; Refresh
300 ; Retry
3600000 ; Expire
3600 ) ; Negative Cache TTL
sitddns.com. IN NS ns1.sitddns.com.
ns1.sitddns.com. IN A 192.168.16.1
sitddns.com. IN A 192.168.16.1
www.sitddns.com. IN CNAME sitddns.com.
vim /etc/dhcp/dhcpd.conf
authoritative;
log-facility local7;
default-lease-time 600;
max-lease-time 7200;
option domain-name "sitddns.com";
option domain-name-servers 192.168.16.1;
ddns-updates on;
ddns-update-style standard;
ddns-domainname "sitddns.com.";
update-optimization off;
update-conflict-detection false;
allow client-updates;
zone sitddns.com. {
primary 192.168.16.1;
}
subnet 192.168.16.0 netmask 255.255.255.0 {
range 192.168.16.5 192.168.16.250;
option routers 192.168.16.1;
}
vim /etc/dhcp/dhcpd6.conf
authoritative;
log-facility local7;
allow leasequery;
default-lease-time 2592000;
preferred-lifetime 604800;
option dhcp-renewal-time 3600;
option dhcp-rebinding-time 7200;
option dhcp6.domain-search "sitddns.com";
option dhcp6.name-servers 2018:1:1:1::1;
ddns-updates on;
ddns-update-style standard;
ddns-domainname "sitddns.com.";
update-optimization off;
update-conflict-detection false;
allow client-updates;
zone sitddns.com. {
primary 192.168.16.1;
}
subnet6 2018:1:1:1::/64 {
range6 2018:1:1:1::5 2018:1:1:1::9999;
}
option dhcp6.info-refresh-time 21600;
vim /etc/default/isc-dhcp-server
service isc-dhcp-server restart
service isc-dhcp-server status
service isc-dhcp-server6 restart
service isc-dhcp-server6 status
service bind9 restart
service bind9 status
# nsupdate
> server 127.0.0.1
> update delete www.sit.com A
> update add www.sit.com 600 A 192.168.1.1
> send
> quit
>-------------------------------------------------------------------------<
find json xpath
from robot.api import logger
class ff(object):
ROBOT_LIBRARY_SCOPE = 'TEST SUITE'
def __init__(self):
def traverse(self, path, obj):
self.list_temp = []
cnt = -1
if isinstance(obj, dict):
d = obj
for k, v in d.items():
if isinstance(v, dict):
self.traverse("{path}.{k}".format(path=path, k=k),v)
elif isinstance(v, list):
self.traverse("{path}.{k}".format(path=path, k=k),v)
else:
self.list_temp.append("{path}.{k} => {v}".format(path=path, k=k, v=v))
if isinstance(obj, list):
li = obj
for e in li:
cnt += 1
if isinstance(e, dict):
self.traverse("{path}[{cnt}]".format(path=path, cnt=cnt), e)
elif isinstance(e, list):
self.traverse("{path}[{cnt}]".format(path=path, cnt=cnt), e)
else:
self.list_temp.append("{path}[{cnt}] => {e}".format(path=path, cnt=cnt, e=e))
return self.list_temp
def jsontolist(self,obj):
self.traverse ("root",obj)
from robot.api.deco import keyword
@keyword
def find_jsonpath_of_specific_value(json_obj, specific_value, path=None, list_temp=None):
if path is None:
path = ''
if list_temp is None:
list_temp = []
count = -1
if isinstance(json_obj, dict):
dict_obj = json_obj
for key, value in dict_obj.items():
temp_path = "{path}.['{key}']".format(path=path, key=key)
if isinstance(value, (dict, list)):
find_jsonpath_of_specific_value(value, specific_value, temp_path, list_temp)
else:
if value == specific_value:
list_temp.append(temp_path)
elif isinstance(json_obj, list):
list_obj = json_obj
for element in list_obj:
count += 1
temp_path = "{path}[{count}]".format(path=path, count=count)
if isinstance(element, (dict, list)):
find_jsonpath_of_specific_value(element, specific_value, temp_path, list_temp)
else:
if element == specific_value:
list_temp.append(temp_path)
return list_temp
>-------------------------------------------------------------------------<
netplan
vim /etc/netplan/
network:
ethernets:
ens160:
addresses:
- 192.148.1.1/16
- 2017:17::1/128
gateway4: 192.148.255.254
gateway6: fe80::3efd:feff:fe9e:bd98
nameservers:
addresses: [168.95.1.1,8.8.8.8]
dhcp4: false
dhcp6: false
version: 2
renderer: NetworkManager
netplan try
netplan apply
>-------------------------------------------------------------------------<
lowdb
const express = require('express');
const bodyParser = require('body-parser');
const low = require('lowdb');
const FileAsync = require('lowdb/adapters/FileAsync');
const app = express();
app.use(bodyParser.json())
const adapter = new FileAsync('db.json');
const { exec } = require('child_process');
var https = require('https');
const fs = require('fs');
low(adapter)
.then(db => {
app.get('/getsnmptrapd/:ip', (req, res) => {
console.log("\n get getsnmptrapd")
console.log(new Date().toLocaleDateString() + " " + new Date().toLocaleTimeString())
console.log(req.params.ip);
db.get('snmptrapd').filter((v) => { return v.using < Date.now() }).map('id').value().forEach((i) => { db.get('snmptrapd').find({ id: i }).assign({ using: 0 }).write() });
var unused = db.get('snmptrapd').find({ using: 0 }).value()
var unused_id = unused == undefined ? 0 : unused.id;
console.log("unused_id: " + unused_id);
var list1 = ['2', '3', '4', '5', '6', '7', '8', '9'];
if (list1.indexOf(unused_id) > -1) {
//7200000 2hr
db.get('snmptrapd').find({ id: unused_id }).assign({ using: Date.now() + 7200000, tester: req.params.ip }).write()
var output = db.get('snmptrapd').find({ id: unused_id }).value()
res.status(200).send(output);
} else {
res.status(500).send("sold out");
}
})
app.get('/releasesnmptrapd/:id', (req, res) => {
console.log("\n get releasesnmptrapd")
console.log(new Date().toLocaleDateString() + " " + new Date().toLocaleTimeString())
console.log(req.params.id);
db.get('snmptrapd').find({ id: req.params.id }).assign({ using: 0, tester: "" }).write()
res.status(200).send("released");
})
app.get('/getsmtp/:ip', (req, res) => {
console.log("\n get getsmtp")
console.log(new Date().toLocaleDateString() + " " + new Date().toLocaleTimeString())
console.log(req.params.ip);
db.get('smtp').filter((v) => { return v.using < Date.now() }).map('id').value().forEach((i) => { db.get('smtp').find({ id: i }).assign({ using: 0 }).write() });
var unused = db.get('smtp').find({ using: 0 }).value()
var unused_id = unused == undefined ? 0 : unused.id;
console.log("unused_id: " + unused_id);
var list1 = ['1', '2', '3', '4', '5', '6', '7', '8', '9'];
if (list1.indexOf(unused_id) > -1) {
//7200000 2hr
db.get('smtp').find({ id: unused_id }).assign({ using: Date.now() + 7200000, tester: req.params.ip }).write()
var output = db.get('smtp').find({ id: unused_id }).value()
res.status(200).send(output);
} else {
res.status(500).send("sold out");
}
})
app.get('/releasesmtp/:id', (req, res) => {
console.log("\n get releasesmtp")
console.log(new Date().toLocaleDateString() + " " + new Date().toLocaleTimeString())
console.log(req.params.id);
db.get('smtp').find({ id: req.params.id }).assign({ using: 0, tester: "" }).write()
res.status(200).send("released");
})
app.get('/getlogserver/:ip', (req, res) => {
console.log("\n get getlogserver")
console.log(new Date().toLocaleDateString() + " " + new Date().toLocaleTimeString())
console.log(req.params.ip);
db.get('logserver').filter((v) => { return v.using < Date.now() }).map('id').value().forEach((i) => { db.get('logserver').find({ id: i }).assign({ using: 0 }).write() });
var unused = db.get('logserver').find({ using: 0 }).value()
var unused_id = unused == undefined ? 0 : unused.id;
console.log("unused_id: " + unused_id);
var list1 = ['1'];
if (list1.indexOf(unused_id) > -1) {
db.get('logserver').find({ id: unused_id }).assign({ using: Date.now() + 180000, tester: req.params.ip }).write()
var output = db.get('logserver').find({ id: unused_id }).value()
res.status(200).send(output);
} else {
res.status(500).send("sold out");
}
})
app.get('/releaselogserver/:id', (req, res) => {
console.log("\n get releaselogserver")
console.log(new Date().toLocaleDateString() + " " + new Date().toLocaleTimeString())
console.log(req.params.id);
db.get('logserver').find({ id: req.params.id }).assign({ using: 0, tester: "" }).write()
res.status(200).send("released");
})
app.get('/getpostserver/:ip', (req, res) => {
console.log("\n get getpostserver")
console.log(new Date().toLocaleDateString() + " " + new Date().toLocaleTimeString())
console.log(req.params.ip);
db.get('postserver').filter((v) => { return v.using < Date.now() }).map('id').value().forEach((i) => { db.get('postserver').find({ id: i }).assign({ using: 0 }).write() });
var unused = db.get('postserver').find({ using: 0 }).value()
var unused_id = unused == undefined ? 0 : unused.id;
console.log("unused_id: " + unused_id);
var list1 = ['1', '2', '3', '4', '5', '6', '7', '8', '9'];
if (list1.indexOf(unused_id) > -1) {
db.get('postserver').find({ id: unused_id }).assign({ using: Date.now() + 180000, tester: req.params.ip }).write()
var output = db.get('postserver').find({ id: unused_id }).value()
res.status(200).send(output);
} else {
res.status(500).send("sold out");
}
})
app.get('/releasepostserver/:id', (req, res) => {
console.log("\n get releasepostserver")
console.log(new Date().toLocaleDateString() + " " + new Date().toLocaleTimeString())
console.log(req.params.id);
db.get('postserver').find({ id: req.params.id }).assign({ using: 0, tester: "" }).write()
res.status(200).send("released");
})
})
.then(() => {
app.listen(80, () => console.log('listening on port 80'))
})
app.get('/', function (req, res) {
res.status(200).send("HI");
});
app.get('/db', function (req, res) {
exec('cat db.json', (error, stdout, stderr) => {
res.status(200).send(JSON.parse(stdout.toString()));
});
});
app.post('/post/:id', function (req, res) {
fs.appendFile('/tmp/post' + req.params.id + '.txt', JSON.stringify(req.body), 'utf8', (err) => {
if (err) throw err;
res.status(200).send("OK");
});
});
app.get('/clearpost/:id', function (req, res) {
exec('echo -n "" > /tmp/post' + req.params.id + '.txt', (error, stdout, stderr) => {
if (error) {
console.error(
exec error: ${error}
);return;
}
res.status(200).send("cleared");
});
});
app.get('/getpost/:id', function (req, res) {
exec('cat /tmp/post' + req.params.id + '.txt | jq --slurp --compact-output .', (error, stdout, stderr) => {
if (error) {
console.error(
exec error: ${error}
);return;
}
res.status(200).send(stdout.toString());
});
});
app.get('/cleartrap/:id', (req, res) => {
console.log("\n get cleartrap")
console.log(new Date().toLocaleDateString() + " " + new Date().toLocaleTimeString())
exec('echo -n "" > /tmp/snmptrapd' + req.params.id + '/snmptrap.txt', (error, stdout, stderr) => {
if (error) {
console.error(
exec error: ${error}
);return;
}
res.status(200).send("cleared");
});
})
app.get('/gettrap/:id', (req, res) => {
console.log("\n get gettrap")
console.log(new Date().toLocaleDateString() + " " + new Date().toLocaleTimeString())
exec('cat /tmp/snmptrapd' + req.params.id + '/snmptrap.txt|tr -d "\\0"|sed -e "s/2019-/\\n2019-/"|sed -e "s/2020-/\\n2020-/"', (error, stdout, stderr) => {
if (error) {
console.error(
exec error: ${error}
);return;
}
res.status(200).send(stdout.toString());
});
})
app.get('/clearemail/:smtpip/:email', (req, res) => {
console.log("\n get clearemail")
console.log(new Date().toLocaleDateString() + " " + new Date().toLocaleTimeString())
exec('./clearemail.sh' + " " + req.params.smtpip + " " + req.params.email, (error, stdout, stderr) => {
if (error) {
console.error(
exec error: ${error}
);return;
}
res.status(200).send("cleared");
});
})
app.get('/getemail/:smtpip/:email', (req, res) => {
console.log("\n getemail")
console.log(new Date().toLocaleDateString() + " " + new Date().toLocaleTimeString())
exec('./getemail.sh' + " " + req.params.smtpip + " " + req.params.email, (error, stdout, stderr) => {
if (error) {
console.error(
exec error: ${error}
);return;
}
res.status(200).send(stdout.toString());
});
})
app.get('/clearsyslog', (req, res) => {
exec('echo -n "" > /var/log/log.txt', (error, stdout, stderr) => {
if (error) {
console.error(
exec error: ${error}
);return;
}
res.status(200).send("OK");
});
})
app.get('/getsyslog', (req, res) => {
exec('cat /var/log/log.txt', (error, stdout, stderr) => {
if (error) {
console.error(
exec error: ${error}
);return;
}
res.status(200).send(stdout.toString());
});
})
app.post('/trapv3user', (req, res) => {
console.log("\n post trapv3user")
console.log(new Date().toLocaleDateString() + " " + new Date().toLocaleTimeString())
// console.log(req.body.name);
// console.log(req.body.pwd);
// console.log(req.body.auth);
// console.log(req.body.priv);
// console.log(req.body.engineid);
// console.log(req.body.snmpid);
if (req.body.name && req.body.pwd && req.body.auth && req.body.priv && req.body.engineid && req.body.snmpid) {
exec('echo createUser -e ' + req.body.engineid + ' ' + req.body.name + ' ' + req.body.auth + ' \\"' + req.body.pwd + '\\" ' + req.body.priv + '>> /etc/snmp/snmptrapd.conf', (error, stdout, stderr) => {
if (error !== null) {
console.error(
exec error: ${error}
);return;
}
exec('docker stop snmptrapd' + req.body.snmpid + ';docker run --net=mynet --ip=192.148.1.' + req.body.snmpid + ' --ip6=2017:17::' + req.body.snmpid + ' -itd --rm -p 162:162/udp -v /tmp/snmptrapd' + req.body.snmpid + ':/tmp -v /etc/snmp:/etc/snmp --name snmptrapd' + req.body.snmpid + ' snmptrapd;' + 'sleep 2;echo -n "" > /tmp/snmptrapd' + req.body.snmpid + '/snmptrap.txt;');
console.log('echo docker stop snmptrapd' + req.body.snmpid + ';docker run --net=mynet --ip=192.148.1.' + req.body.snmpid + ' --ip6=2017:17::' + req.body.snmpid + ' -itd --rm -p 162:162/udp -v /tmp/snmptrapd' + req.body.snmpid + ':/tmp -v /etc/snmp:/etc/snmp --name snmptrapd' + req.body.snmpid + ' snmptrapd;');
res.status(200).send("OK");
});
} else {
res.status(500).send("params error");
}
})
https.createServer({
key: fs.readFileSync('server.key'),
cert: fs.readFileSync('server.cert')
}, app)
.listen(443, function () {
console.log('listening on port 443')
})
>-------------------------------------------------------------------------<
woo
const puppeteer = require('puppeteer');
(async () => {
async function leaveChat() {
await page.evaluate(() => {
document.querySelector('#messageInput').value = '';
document.querySelector('input[value=離開]').click();
document.querySelector('#popup-yes').click();
setTimeout(() => {
document.querySelector('#ensureText').value = 'leave';
document.querySelector('#popup-yes').click();
}, 1);
});
await page.evaluate(() => {
setTimeout(() => {
document.querySelector('#startButton').click();
}, 1000);
});
}
const browser = await puppeteer.launch({
userDataDir: './userdir',
executablePath:
'C:\\Program Files\\Google\\Chrome\\Application\\chrome.exe',
headless: false,
args: [
'--no-proxy-server', '--enable-automation', '--mute-audio', '--window-size=340,520', '--app=https://wootalk.today/'
]
});
const page = (await browser.pages())[0];
// await page.setUserAgent('Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:75.0) Gecko/20100101 Firefox/75.0');
// await page.setUserAgent('Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/80.0.3987.163 Safari/537.36');
// await page.setUserAgent('Mozilla/5.0 (Linux; Android 10; Pixel 4 XL) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/81.0.4044.111 Mobile Safari/537.36');
// await page.setViewport({ width: 400, height: 600 });
await page.emulate(puppeteer.devices['iPhone 4']);
// await page.goto('https://wootalk.today/');
await page.waitForSelector('#startButton');
await page.click('#startButton');
await page._client.on('Network.webSocketFrameReceived', ({ requestId, timestamp, response }) => {
// console.log(response.payloadData);
if (response.payloadData.indexOf('對方離開了') > 0) {
if (this.leaveing != 1) {
this.leaveing = 1
console.log("::::::::::::對方離開了");
leaveChat()
setTimeout(() => {
this.leaveing = 0
}, 100);
}
} else if (response.payloadData.indexOf('[["client_connected"') == 0) {
this.starttime = response.payloadData
this.LastMessageTime = response.payloadData
setTimeout((starttime = response.payloadData) => {
if (starttime == this.starttime && starttime == this.LastMessageTime) {
console.log("::::::::::::不說話");
setTimeout(() => {
leaveChat()
}, 100);
}
}, 10000);
} else if (response.payloadData.indexOf('[["new_message"') == 0 && response.payloadData.indexOf('device') > 0) {
const aRegExp = /\{.*\}/;
const newMessage = JSON.parse(response.payloadData.match(aRegExp));
if (this.LastMessageTime != newMessage.data.time) {
this.LastMessageTime = newMessage.data.time;
if (response.payloadData.indexOf('"sender":2') > 0) {
console.log(newMessage.data.message);
if (newMessage.data.id < 4) {
var substrings = ["男", "叔", "弟", "找", "嗎", "女?", "女?", "女生?"];
if (substrings.some(function (v) { return newMessage.data.message.indexOf(v) >= 0; })) {
console.log("::::::::::::主動離開");
setTimeout(() => {
leaveChat()
}, 1000);
} else if (newMessage.data.id == 0) {
page.evaluate(() => {
const a1 = ["男", "男生", "男的"];
const a2 = ["Hi", "妳好", "安安"];
document.querySelector('#messageInput').value = a1[Math.floor(Math.random() * a1.length)];
document.querySelector('input[value=傳送]').click();
document.querySelector('#messageInput').value = a2[Math.floor(Math.random() * a2.length)];
document.querySelector('input[value=傳送]').click();
});
}
}
}
}
}
});
})();
>-------------------------------------------------------------------------<
kerberos
vim /etc/hosts
192.168.212.224 remote.example.com remote
192.168.212.199 server.example.com server
192.168.212.139 client.example.com client
hostnamectl set-hostname remote.example.com
hostnamectl set-hostname server.example.com
hostnamectl set-hostname client.example.com
kerberos
server
client
server 192.168.16.1
update add remote.example.com 0 A 192.168.212.224
update add server.example.com 0 A 192.168.212.199
update add client.example.com 0 A 192.168.134.207
systemctl start kadmin krb5kdc
systemctl enable kadmin krb5kdc
systemctl status kadmin krb5kdc
netstat -tlunp
systemctl start kadmin
systemctl enable kadmin
systemctl restart chronyd
systemctl enable chronyd
systemctl status chronyd
firewall-cmd --add-service=nfs
firewall-cmd --add-service=nfs --permanent
firewall-cmd --add-rich-rule='rule family="ipv4" source address="192.168.0.0/16" accept'
firewall-cmd --add-rich-rule='rule family="ipv4" source address="192.168.0.0/16" accept' --permanent
systemctl restart nfs-client.target
systemctl enable nfs-client.target
systemctl status rpc-gssd
systemctl stop firewalld.service
systemctl disable firewalld.service
systemctl restart kadmin
systemctl restart kerberos
addprinc -randkey host/remote.example.com
addprinc -randkey host/server.example.com
addprinc -randkey host/client.example.com
addprinc -randkey nfs/remote.example.com
addprinc -randkey nfs/server.example.com
addprinc -randkey nfs/client.example.com
scp remote:/etc/krb5.conf /etc
ktadd host/server.example.com@EXAMPLE.COM
ktadd nfs/server.example.com@EXAMPLE.COM
ktadd -k /root/client.keytab host/client.example.com@EXAMPLE.COM
ktadd -k /root/client.keytab nfs/client.example.com@EXAMPLE.COM
systemctl stop firewalld
systemctl disable firewalld
vim /etc/selinux/config
vim /etc/fstab
systemctl restart nfs-secure
showmount -e server
mount -a
vim /etc/fstab
192.168.212.199:/nfs1 /mnt/nfs nfs defaults,v4.2,sec=krb5p 0 0
mount -t nfs4 -o sec=krb5 server:/nfs1 /mnt/nfs
>-------------------------------------------------------------------------<
pm2
npm install pm2 -g
pm2 start --name app app.js
pm2 startup
pm2 save
pm2 logs [--raw] # Display all processes logs in streaming
pm2 flush # Empty all log files
pm2 reloadLogs # Reload all logs
>-------------------------------------------------------------------------<
ldap
ssl
https://www.server-world.info/en/note?os=Ubuntu_16.04&p=openldap&f=4
log
https://www.openldap.org/doc/admin24/slapdconf2.html
starttls
https://ubuntu.com/server/docs/service-ldap-with-tls
https://docs.oracle.com/cd/E17952_01/mysql-5.5-en/creating-ssl-files-using-openssl.html
https://help.ubuntu.com/community/SecuringOpenLDAPConnections
-----------------------------------------------------------------------
apt install -y slapd ldap-utils
dpkg-reconfigure slapd
vim /etc/ldap/ldap.conf
BASE dc=ex,dc=com
URI ldap:// ldaps://
TLS_CACERT /etc/ldap/sasl2/ca.pem
-----------------------------------------------------------------------
yum -y install openldap openldap-clients openldap-servers
rpm -qa |grep openldap
systemctl stop firewalld
systemctl disable firewalld
systemctl mask --now firewalld
slappasswd -h {SSHA} -s 123456
echo 'local4.* /var/log/ldap.log' >> /etc/rsyslog.conf
service rsyslog restart
ldapadd -Y EXTERNAL -H ldapi:/// -f /etc/openldap/schema/cosine.ldif
ldapadd -Y EXTERNAL -H ldapi:/// -f /etc/openldap/schema/nis.ldif
ldapadd -Y EXTERNAL -H ldapi:/// -f /etc/openldap/schema/inetorgperson.ldif
vim /etc/sysconfig/slapd
-----------------------------------------------------------------------
cn=config.ldif
olcLogLevel: -1
olcDatabase={2}hdb.ldif
olcSuffix: dc=ex,dc=com
olcRootDN: cn=admin,dc=ex,dc=com
olcRootPW: {SSHA}AAN+WziS3s6IxXcY+TagzfkNbNbkndPf
olcSecurity: tls=1
https://askubuntu.com/questions/1210313/openldap-trouble-setting-tls-cipher-list
dn: cn=config
changetype: modify
add: olcTLSCipherSuite
olcTLSCipherSuite: SECURE256:+SECURE128:-VERS-TLS-ALL:+VERS-TLS1.2:+VERS-DTLS1.2:-RSA:-DHE-DSS:-CAMELLIA-128-CBC:-CAMELLIA-256-CBC
-----------------------------------------------------------------------
config.ldif
# AUTO-GENERATED FILE - DO NOT EDIT!! Use ldapmodify.
# CRC32 e35f741b
dn: cn=config
objectClass: olcGlobal
cn: config
olcArgsFile: /var/run/slapd/slapd.args
olcLogLevel: none
olcPidFile: /var/run/slapd/slapd.pid
olcToolThreads: 1
structuralObjectClass: olcGlobal
entryUUID: 0908239a-20c1-103b-87dc-7d261b19268a
creatorsName: cn=config
createTimestamp: 20210324074815Z
entryCSN: 20210324074815.323340Z#000000#000#000000
modifiersName: cn=config
modifyTimestamp: 20210324074815Z
olcTLSCACertificateFile: /etc/ldap/sasl2/ca.pem
olcTLSCertificateFile: /etc/ldap/sasl2/cert.pem
olcTLSCertificateKeyFile: /etc/ldap/sasl2/key.pem
olcTLSCipherSuite: SECURE256:+SECURE128:-VERS-TLS-ALL:+VERS-TLS1.2:+VERS-DTL
S1.2:-RSA:-DHE-DSS:-CAMELLIA-128-CBC:-CAMELLIA-256-CBC
-----------------------------------------------------------------------
ldapwhoami -H ldap://ex.com -x -ZZ
/usr/sbin/slapd -d 1 -h "ldap:/// ldapi:/// ldaps:///" -g openldap -u openldap -F /etc/ldap/slapd.d
-----------------------------------------------------------------------
-----------------------------------------------------------------------
dn: dc=ex,dc=com
dc: ex
objectClass: top
objectClass: dcObject
objectClass: organization
o: ex.com
dn: cn=admin, dc=ex,dc=com
userPassword:: e1NIQX1mRXFOQ2NvM1lxOWg1WlVnbEQzQ1pKVDRsQnM9
description: LDAP administrator
objectClass: simpleSecurityObject
objectClass: organizationalRole
cn: admin
dn: ou=People, dc=ex,dc=com
ou: People
objectClass: organizationalUnit
dn: uid=user1,ou=People, dc=ex,dc=com
loginShell: /bin/bash
gidNumber: 18001
userPassword:: e1NIQX1mRXFOQ2NvM1lxOWg1WlVnbEQzQ1pKVDRsQnM9
uidNumber: 18001
uid: user1
objectClass: top
objectClass: account
objectClass: posixAccount
homeDirectory: /home/user1
cn: user1
dn: uid=user2,ou=People, dc=ex,dc=com
loginShell: /bin/bash
gidNumber: 18002
userPassword:: e1NIQX1mRXFOQ2NvM1lxOWg1WlVnbEQzQ1pKVDRsQnM9
uidNumber: 18002
uid: user2
objectClass: top
objectClass: account
objectClass: posixAccount
homeDirectory: /home/user2
cn: user2
dn: uid=user3,ou=People, dc=ex,dc=com
loginShell: /bin/bash
gidNumber: 18003
userPassword:: e1NIQX1mRXFOQ2NvM1lxOWg1WlVnbEQzQ1pKVDRsQnM9
uidNumber: 18003
uid: user3
objectClass: top
objectClass: account
objectClass: posixAccount
homeDirectory: /home/user3
cn: user3
dn: uid=user4,ou=People, dc=ex,dc=com
loginShell: /bin/bash
gidNumber: 18004
userPassword:: e1NIQX1mRXFOQ2NvM1lxOWg1WlVnbEQzQ1pKVDRsQnM9
uidNumber: 18004
uid: user4
objectClass: top
objectClass: account
objectClass: posixAccount
homeDirectory: /home/user4
cn: user4
dn: uid=user5,ou=People, dc=ex,dc=com
loginShell: /bin/bash
gidNumber: 18005
userPassword:: e1NIQX1mRXFOQ2NvM1lxOWg1WlVnbEQzQ1pKVDRsQnM9
uidNumber: 18005
uid: user5
objectClass: top
objectClass: account
objectClass: posixAccount
homeDirectory: /home/user5
cn: user5
dn: uid=usertest,ou=People, dc=ex,dc=com
loginShell: /bin/bash
gidNumber: 18006
userPassword:: e1NIQX1OT2tOMWRYQUtUK0d1WlI2alc4b0RZVHh3YjQ9
uidNumber: 18006
uid: usertest
objectClass: top
objectClass: account
objectClass: posixAccount
homeDirectory: /home/usertest
cn: usertest
dn: uid=suttest,ou=People, dc=ex,dc=com
loginShell: /bin/bash
gidNumber: 18007
userPassword:: e1NIQX1SNkI1aDFMeHNNaHNISVBoUER5NC9ka1pqbzQ9
uidNumber: 18007
uid: suttest
objectClass: top
objectClass: account
objectClass: posixAccount
homeDirectory: /home/suttest
cn: suttest
dn: uid=redfish,ou=People, dc=ex,dc=com
loginShell: /bin/bash
gidNumber: 18008
userPassword:: e1NIQX1SNkI1aDFMeHNNaHNISVBoUER5NC9ka1pqbzQ9
uidNumber: 18008
uid: redfish
objectClass: top
objectClass: account
objectClass: posixAccount
homeDirectory: /home/redfish
cn: redfish
dn: uid=rr123test,ou=People, dc=ex,dc=com
loginShell: /bin/bash
gidNumber: 18009
userPassword:: e1NIQX1JdFF4MUJEajA1c0ZVMjhUOW1sTVpHNTQwYXc9
uidNumber: 18009
uid: rr123test
objectClass: top
objectClass: account
objectClass: posixAccount
homeDirectory: /home/rr123test
cn: rr123test
dn: uid=rr1234test,ou=People, dc=ex,dc=com
loginShell: /bin/bash
gidNumber: 18010
userPassword:: e1NIQX1aZHY5a2RwRkxxa1plTkh2cTBFMENEcjJQUlk9
uidNumber: 18010
uid: rr1234test
objectClass: top
objectClass: account
objectClass: posixAccount
homeDirectory: /home/rr1234test
cn: rr1234test
dn: ou=Group, dc=ex,dc=com
ou: Group
objectClass: organizationalUnit
dn: cn=group1,ou=Group, dc=ex,dc=com
objectClass: groupOfNames
member: uid=user1,ou=People,dc=ex,dc=com
member: uid=suttest,ou=People,dc=ex,dc=com
member: uid=usertest,ou=People,dc=ex,dc=com
member: uid=rr123test,ou=People,dc=ex,dc=com
member: uid=rr1234test,ou=People,dc=ex,dc=com
member: uid=redfish,ou=People,dc=ex,dc=com
cn: group1
dn: cn=group2,ou=Group, dc=ex,dc=com
objectClass: groupOfNames
member: uid=user2,ou=People,dc=ex,dc=com
cn: group2
dn: cn=group3,ou=Group, dc=ex,dc=com
objectClass: groupOfNames
member: uid=user3,ou=People,dc=ex,dc=com
cn: group3
dn: cn=group4,ou=Group, dc=ex,dc=com
objectClass: groupOfNames
member: uid=user4,ou=People,dc=ex,dc=com
cn: group4
dn: cn=group5,ou=Group, dc=ex,dc=com
objectClass: groupOfNames
member: uid=user5,ou=People,dc=ex,dc=com
cn: group5
dn: cn=admin1, dc=ex,dc=com
userPassword:: e1NIQX1mRXFOQ2NvM1lxOWg1WlVnbEQzQ1pKVDRsQnM9
description: LDAP administrator
objectClass: simpleSecurityObject
objectClass: organizationalRole
cn: admin1
※ 編輯: appappf 時間: 2023-01-04 11:21:17 (台灣)
※ 看板: app 文章推薦值: 0 目前人氣: 0 累積人氣: 20
回列表(←)
分享