ubuntu apache2+tomcat command line tool as python instead of service

Posted by nopsled
2019.02.22 17:27 프로그래밍

회사에서 갑자기 VM을 옮기랜다... 까라는대로 까야지...


아무것도 모르는 centos, tomcat, mariadb를 ubuntu, tomcat, mysql로 옮기느라 혼쭐났다. (덕분에 오늘 하루가 빨리 갔다)


열심히 셋팅하고 나니까 느낀점이 apache는 service apache2 start 이런식으로 start하거나 stop과 같은 service가 존재하는데 tomcat은 커맨드라인으로 일일히 해줘야 한다는 것이다.


그래서 귀찮아서 파이썬으로 만들어뒀다.



1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
# -*- coding: utf-8 -*-
import os, sys, commands
 
class Utils():
    def __init__(self):
        # Define variables
        self.TOMCAT_SHUTDOWN = '/usr/tomcat8/bin/shutdown.sh'
        self.TOMCAT_STARTUP = '/usr/tomcat8/bin/startup.sh'
 
        # Don't modify at this 3 line 11~13
        ALLOW_COMMAND = ['status''start''stop''restart']
        self.apache = False
        self.tomcat = False
 
        # Check parameter
        if not len(sys.argv) == 2:
            print '[-] Not enough param'
            exit()
        elif not sys.argv[1].lower() in ALLOW_COMMAND:
            print '[-] Param type : %s' % ', '.join(ALLOW_COMMAND)
            exit()
 
        # Get status
        shell = commands.getoutput("sudo netstat -ntlp").split('\n')
        for row, row_data in enumerate(shell):
            if not row_data.find('apache'== -1:
                self.apache = True
            elif not row_data.find('java'== -1:
                self.tomcat = True
 
        self.dynamic_loader(sys.argv[1])
        return
 
    def status(self):
        print '[*] Apache status %s' % self.apache
        print '[*] Tomcat status %s' % self.tomcat
        return
 
    def start(self):
        if self.apache:
            print '[*] Apache already loaded.'
        else:
            commands.getoutput('sudo service apache2 start')
            print '[*] Apache started'
 
        if self.tomcat:
            print '[*] Tomcat already loaded.'
        else:
            commands.getoutput(self.TOMCAT_STARTUP)
            print '[*] Tomcat started.'
        return
 
    def stop(self):
        if self.apache:
            commands.getoutput('sudo service apache2 stop')
            print '[*] Apache stopped'
        else:
            print '[*] Apache already stopped.'
 
        if self.tomcat:
            commands.getoutput(self.TOMCAT_SHUTDOWN)
            print '[*] Tomcat stopped.'
        else:
            print '[*] Tomcat already stopped.'
        return
 
    def restart(self):
        commands.getoutput('sudo service apache2 restart')
        print '[*] Apache restarted.'
        if self.tomcat:
            commands.getoutput(self.TOMCAT_SHUTDOWN)
        commands.getoutput(self.TOMCAT_STARTUP)
        print '[*] Tomcat restarted.'
        return
 
    def dynamic_loader(self, func_name):
        func = getattr(self, func_name.lower())
        func()
 
if __name__ == '__main__':
    Utils = Utils()
cs

쓸 사람이 있다면 7,8 라인을 수정해서 사용하면 된다.



1
2
3
4
5
6
7
8
9
10
11
12
dataking@360pia:~$ tail ~/.bashrc
# this, if it's already enabled in /etc/bash.bashrc and /etc/profile
# sources /etc/bash.bashrc).
if ! shopt -oq posix; then
  if [ -/usr/share/bash-completion/bash_completion ]; then
    . /usr/share/bash-completion/bash_completion
  elif [ -/etc/bash_completion ]; then
    . /etc/bash_completion
  fi
fi
alias server="python /home/dataking/server.py `$1`"
dataking@360pia:~$
cs


~/.bashrc 맨밑 하단에 위와 같이 추가해주면 커맨드라인으로 사용할 수 있다. (이거 하고나서 shell 로그아웃 안시키고 source ~/.bashrc 사용하면 alias 등록이 바로 된다)



1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
dataking@360pia:~$ server
[-] Not enough param
dataking@360pia:~$ server a
[-] Param type : status, start, stop, restart
dataking@360pia:~$ server status
[*] Apache status True
[*] Tomcat status True
dataking@360pia:~$ server start
[*] Apache already loaded.
[*] Tomcat already loaded.
dataking@360pia:~$ server restart
[*] Apache restarted.
[*] Tomcat restarted.
dataking@360pia:~$ server stop
[*] Apache stopped
[*] Tomcat stopped.
cs

아무튼 alias를 등록하고 해보면 위처럼 보인다



이 댓글을 비밀 댓글로

PUBG API in python

Posted by nopsled
2019.02.14 14:06 일상생활

매일 피시방가서 설정파일을 건드리는게 싫어서 개발하려한다.


PUBG API는 10req/min 으로 제한하고 있고 해당 limitation을 올리려면 문의하라해서 방금 문의하고 왔다.


웬지 영어로 써야할 것 같이 생겨서 하지도 못하는 영어 열심히 끄적였다.


맨날 피시방가서 10분을 여기에 할애해야 한다는게 귀찮아서 해보려고 한다.


현재는 PUBG configuration만 파싱한다고 생각했는데 나중엔 NVIDIA configuration도 파싱해서 서버에서 save, load를 제공하는식으로 해주는것도 나쁘지 않을듯하다.


*** Telling my applications ***

Some people have to modify PUBG configuration every times in game :

  - monitor

  - mouse sensitive

  - etc…


It spend time about 10min per day. have to spend my time about 100 min if I visit pc room.


This problem occur also me.


Finally, I want to share this app for some peoples.



*** what it does ***

1. custom login in my windows application.

2. insert userid, password and click login button

   * not registered user have to register (if click register button, check invalid userid using by PUBG API)

   * safety reason, I will add salt hash on password in server side.

3. save configuration file on server or load configuration file on server only click one button. 


주요 내용은 위와 같다.




현재 대략적인 구상도는 client windows GUI를 python으로 만들고, 백엔드는 python flask+MongoDB로 만들 생각이다.

'일상생활' 카테고리의 다른 글

PUBG API in python  (0) 2019.02.14
중년기사김봉식 매크로  (18) 2018.08.09
18.02.22 전역  (0) 2018.04.25
페이스북 video_xxxx.zip  (0) 2017.12.17
2017.09.12  (0) 2017.09.12
2017.06.10  (0) 2017.06.10
이 댓글을 비밀 댓글로

Azure blob storage SDK set Content-Type using php

Posted by nopsled
2019.02.12 17:41 프로그래밍

Can't find some example that set blob's Content-Type from official site.


Here is example code.


<?php
require_once(__DIR__ . '/autoload.php');

use MicrosoftAzure\Storage\Blob\BlobRestProxy;
use MicrosoftAzure\Storage\Blob\Models\CreateBlockBlobOptions;

// declaration variables
$connectionString = 'INPUT_YOUR_SECRET_KEY';
$containerName = 'testContainer';
$blobName = 'blob.json';
$content = '{"nopsled":"blog"}';
$blobContentType = 'application/json; application/json; charset=UTF-8';

$blobClient = BlobRestProxy::createBlobService($this->connectionString);

$options = new CreateBlockBlobOptions();
$options->setContentType($blobContentType);
$blobClient->createBlockBlob($containerName, $blobName, json_encode($content, JSON_UNESCAPED_UNICODE), $options);
// json_encode korean language using by JSON_UNESCAPED_UNICODE





이 댓글을 비밀 댓글로