Проблеми с CLI на офлайн възел на Jenkins

Искам да превърна един възел в подчинен в офлайн, създадох работа на главния и се опитвам да изпратя офлайн сигнал до конкретен възел. Но имам проблеми с удостоверяването, какво може да бъде?!

Конфигурацията на моята работа на Дженкинс в обвивка за изпълнение:

wget http://local:8080/jnlpJars/jenkins-cli.jar
java -jar jenkins-cli.jar -s http://local:8080/ who-am-i
java -jar jenkins-cli.jar -s http://local:8080/ offline-node "NSD38" --username admin --password admin

На анонимни предостави целия защитен достъп в базираната на Matrix защита. Маркирайте всички точки.

Изход:

+ java -jar jenkins-cli.jar -s http://localhost:8080/ who-am-i
[WARN] Failed to authenticate with your SSH keys. Proceeding as anonymous
Authenticated as: anonymous
Authorities:
anonymous
+ java -jar jenkins-cli.jar -s http://localhost:8080/ offline-node NSD38 --username admin --password  admin
[WARN] Failed to authenticate with your SSH keys. Proceeding as anonymous
java.lang.NullPointerException
at hudson.slaves.OfflineCause$UserCause.<init>(OfflineCause.java:111)
at hudson.slaves.OfflineCause$ByCLI.<init>(OfflineCause.java:128)
at hudson.model.Computer.cliOffline(Computer.java:432)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
at java.lang.reflect.Method.invoke(Method.java:597)
at hudson.cli.declarative.MethodBinder.call(MethodBinder.java:102)
at hudson.cli.declarative.CLIRegisterer$1.main(CLIRegisterer.java:185)
at hudson.cli.CliManagerImpl.main(CliManagerImpl.java:92)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
at java.lang.reflect.Method.invoke(Method.java:597)
at hudson.remoting.RemoteInvocationHandler$RPCRequest.perform(RemoteInvocationHandler.java:299)
at hudson.remoting.RemoteInvocationHandler$RPCRequest.call(RemoteInvocationHandler.java:280)
at hudson.remoting.RemoteInvocationHandler$RPCRequest.call(RemoteInvocationHandler.java:239)
at hudson.remoting.UserRequest.perform(UserRequest.java:118)
at hudson.remoting.UserRequest.perform(UserRequest.java:48)
at hudson.remoting.Request$2.run(Request.java:328)
at hudson.remoting.InterceptingExecutorService$1.call(InterceptingExecutorService.java:72)
at hudson.cli.CliManagerImpl$1.call(CliManagerImpl.java:63)
at hudson.remoting.InterceptingExecutorService$2.call(InterceptingExecutorService.java:95)
at java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:303)
at java.util.concurrent.FutureTask.run(FutureTask.java:138)
at java.util.concurrent.ThreadPoolExecutor$Worker.runTask(ThreadPoolExecutor.java:895)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:918)
at java.lang.Thread.run(Thread.java:662)
Build step 'Execute shell' marked build as failure
Notifying upstream projects of job completion
Finished: FAILURE

person Vladimir Voitekhovski    schedule 28.04.2014    source източник


Отговори (3)


Прочетете това тук, раздел, озаглавен Работа с идентификационни данни.

Трябва да използвате -i private_key_file, освен ако нямате съхранен локален частен ключ. Този ключ първо трябва да бъде конфигуриран в конфигурацията на Jenkins

person Slav    schedule 28.04.2014
comment
Но защо, ако се опита да влезе като анонимен, не го прави? - person Vladimir Voitekhovski; 28.04.2014
comment
Тъй като конфигурацията на вашия сървър вероятно не позволява на anonymous потребител да прави такива промени. Винаги можете да опитате да изключите удостоверяването в конфигурацията на Jenkins и да изберете Everyone can do anything и да опитате отново командния ред. - person Slav; 28.04.2014
comment
са направили както казахте и няма промени (изграждането е неуспешно със същите проблеми - person Vladimir Voitekhovski; 28.04.2014

Срещнах същия проблем преди няколко дни. Успях да го разреша, като първо извиках командата за влизане.

java -jar jenkins-cli.jar -s http://local:8080/ login --username admin --password admin
java -jar jenkins-cli.jar -s http://local:8080/ offline-node "NSD38" --username admin --password admin
person Andy Chen    schedule 30.04.2014

Разреших този проблем, първо опитайте да влезете първо, преди да извикате команда, но нямаше промени и след това просто създадох ключ за добавяне на shh към потребителското поле на jenkins и всичко е наред.

person Vladimir Voitekhovski    schedule 02.05.2014