[작성자:] 이대원

  • ddclinet+cloudflare+freenom 조합으로 서버 운영하기

    ddclinet+cloudflare+freenom 조합으로 서버 운영하기

    ddclient+cloudflare+freenom 조합으로 서버 운영하기

    이사가기 전에는 서버를 공유기 아래에 물려 사용하고 있었다. iptime 싸구려 공유기를-가성비 갑- 사용 중이다. 제작사가 일괄적으로 ***.iptime.org의 도메인을 등록해 놓고, 공유기에서 메뉴로 사용 여부를 가능하게 했다. 도메인이 *.iptime.org 이런 형식으로 끝나, iptime 공유기 사용하는 티가 너무 났다. 이런 점을 노리고 제작사에서 이런 기능을 넣었을 듯 하다. 또한 서버가 공유기 아래에 있어, 싸구려 공유기가 죽어버리면 외부에서 서버를 연결 할 수 없다.

    새로 이사한 이후에는 집으로 랜선이 5개 정도 들어왔는데, 인터넷 회사가 2개 회선을 기본적으로 제공했다. 1개선은 공유기로, 1개선은 IPTV/gen8로 연결 했다. IPTV의 셋톱 박스에서 나오는 랜선 포트가 하나 있는데, 그 선을 gen8로 연결하면, 서버가 공인 IP를 사용할 수 있다.

    (=:외부 랜선, -:내부 랜선)

    ……………..gen8===IPTV============

    …PC———공유기============
    …………….|
    휴대폰—–|

    공유기 배선도

    gen8에서 핑을 구글로 넣으면 응답이 있는데, 네이버나 다음으로는 핑이 안나간다. 아마 인터넷 회사에서 그쪽으로 나가는 핑을 막아놓은 듯 보인다.

    도메인은 freenom에서 무료로 얻었다. 2017년 12월까지 1년동안 사용할 수 있다. 만료되기 전, 적정한 시점에 도메인 사용 연장 신청을 해야 도메인을 잃어버리지 않는다. 상당히 귀찮지만, 이게 싫으면 돈을 내면 된다. KISA가 제공하는 국내 도메인도 있는데, 일년에 만원 정도 내야 된다. 게다가 2차 도메인이라 주소 입력하기가 좀 귀찮다. 일단 무료 도메인을 사용하기로 했다. freenom에서 nameserver를 cloudflare로 설정 했다.

    요즘 cloudflare를 많이 사용하는데, cloudflare가 무료로 DDNS를 지원하기 때문이다. 데비안 서버에서 DDNS로 IP를 업데이트 하기 위해서는, ddclient를 사용해야 한다. 예상대로 경험자들이 인터넷에 문서를 많이 남겨 놓았다. 이를 참조하여 설정했다.했다. cloudflare는 웹서버 캐시도 지원 하는데, 굳이 사용할 필요는 없어 보인다. 일단 cloudflare에서 freenom에서 구한 도메인과 DHCP로 받은 IP를 넣어 준다.
    클라우드플레어

    ddclient 3.8.3부터 cloudflare를 지원하는데, deb 페키지가 없어 압축파일을 직접 설치했다. README.md 파일을 보면, sample을 설정해 놓았는데, 이를 참조하여 설정했다. ddclient가 cloudflare로 접속을 하기 위해서는 API key가 있어야 된다. cloudflare에서 API key를 확인할 수 있다. 대략 설정 파일은 아래와 같다. 아래 설정 기준으로, password 아래 “now0930.tk”가 cloudflare에서 업데이트할 도메인 이름이다. 사용자가 이를 입력하지 않으면, ddclient가 업데이트를 하지 않는다.

    protocol=cloudflare,        \
    zone=now0930.tk,            \
    server=www.cloudflare.com,  \
    login=*************,     \
    password=********************** \
    now0930.tk
    #domain.tld,my.domain.tld

    daemon모드로 설정을 하면, 부팅과 동시에 실행되는 듯 하다. 실행 관련 별도 설정을 하지 않았다.

    IP가 제대로 변경되는지 확인하기 위해서, cloudflare에서 틀린 IP로 설정을 했다. 이후 ddclient를 디버그 모드로 실행하여 그 결과를 보았다. IP가 변경이 되면, 설정이 정확한 것이다.

    ddclient -daemon=0 -noquiet -debug -verbose

    === opt ====
    opt{cache}                           : <undefined>
    opt{cmd}                             : <undefined>
    opt{cmd-skip}                        : <undefined>
    opt{daemon}                          : 0
    opt{debug}                           : 1
    opt{exec}                            : <undefined>
    opt{facility}                        : <undefined>
    opt{file}                            : <undefined>
    opt{force}                           : <undefined>
    opt{foreground}                      : <undefined>
    opt{fw}                              : <undefined>
    opt{fw-login}                        : <undefined>
    opt{fw-password}                     : <undefined>
    opt{fw-skip}                         : <undefined>
    opt{geturl}                          : <undefined>
    opt{help}                            : <undefined>
    opt{host}                            : <undefined>
    opt{if}                              : <undefined>
    opt{if-skip}                         : <undefined>
    opt{ip}                              : <undefined>
    opt{login}                           : <undefined>
    opt{mail}                            : <undefined>
    opt{mail-failure}                    : <undefined>
    opt{max-interval}                    : 2160000
    opt{min-error-interval}              : 300
    opt{min-interval}                    : 30
    opt{options}                         : <undefined>
    opt{password}                        : <undefined>
    opt{pid}                             : <undefined>
    opt{postscript}                      : <undefined>
    opt{priority}                        : <undefined>
    opt{protocol}                        : <undefined>
    opt{proxy}                           : <undefined>
    opt{query}                           : <undefined>
    opt{quiet}                           : 0
    opt{retry}                           : <undefined>
    opt{server}                          : <undefined>
    opt{ssl}                             : <undefined>
    opt{syslog}                          : <undefined>
    opt{test}                            : <undefined>
    opt{timeout}                         : <undefined>
    opt{use}                             : <undefined>
    opt{verbose}                         : 1
    opt{web}                             : <undefined>
    opt{web-skip}                        : <undefined>
    === globals ====
    globals{cache}                       : /var/cache/ddclient/ddclient.cache
    globals{daemon}                      : 60
    globals{debug}                       : 1
    globals{mail}                        : root
    globals{mail-failure}                : root
    globals{pid}                         : /var/run/ddclient.pid
    globals{quiet}                       : 0
    globals{ssl}                         : 1
    globals{syslog}                      : 1
    globals{use}                         : web
    globals{verbose}                     : 1
    === config ====
    config{now0930.tk}{atime}            : 0
    config{now0930.tk}{backupmx}         : 0
    config{now0930.tk}{cacheable}        : ARRAY(0x2594678)
    config{now0930.tk}{cmd}              : <undefined>
    config{now0930.tk}{cmd-skip}         : 
    config{now0930.tk}{fw}               : 
    config{now0930.tk}{fw-login}         : <undefined>
    config{now0930.tk}{fw-password}      : 
    config{now0930.tk}{fw-skip}          : 
    config{now0930.tk}{host}             : now0930.tk
    config{now0930.tk}{if}               : ppp0
    config{now0930.tk}{if-skip}          : 
    config{now0930.tk}{ip}               : <undefined>
    config{now0930.tk}{login}            : **************
    config{now0930.tk}{max-interval}     : 2160000
    config{now0930.tk}{min-error-interval} : 300
    config{now0930.tk}{min-interval}     : 300
    config{now0930.tk}{mtime}            : 0
    config{now0930.tk}{mx}               : 
    config{now0930.tk}{password}         : ********************
    config{now0930.tk}{protocol}         : cloudflare
    config{now0930.tk}{server}           : www.cloudflare.com
    config{now0930.tk}{static}           : 0
    config{now0930.tk}{status}           : 
    config{now0930.tk}{use}              : web
    config{now0930.tk}{warned-min-error-interval} : 0
    config{now0930.tk}{warned-min-interval} : 0
    config{now0930.tk}{web}              : dyndns
    config{now0930.tk}{web-skip}         : 
    config{now0930.tk}{wildcard}         : 0
    config{now0930.tk}{wtime}            : 30
    config{now0930.tk}{zone}             : now0930.tk
    === cache ====
    cache{now0930.tk}{atime}             : 0
    cache{now0930.tk}{backupmx}          : 0
    cache{now0930.tk}{host}              : now0930.tk
    cache{now0930.tk}{ip}                : **************
    cache{now0930.tk}{mtime}             : 1480776823
    cache{now0930.tk}{mx}                : 
    cache{now0930.tk}{static}            : 0
    cache{now0930.tk}{status}            : 
    cache{now0930.tk}{warned-min-error-interval} : 0
    cache{now0930.tk}{warned-min-interval} : 0
    cache{now0930.tk}{wildcard}          : 0
    cache{now0930.tk}{wtime}             : 30
    DEBUG:    proxy  = 
    DEBUG:    url    = http://checkip.dyndns.org/
    DEBUG:    server = checkip.dyndns.org
    CONNECT:  checkip.dyndns.org
    CONNECTED:&nbsp; using HTTP
    SENDING:&nbsp; GET / HTTP/1.0
    SENDING:&nbsp;&nbsp; Host: checkip.dyndns.org
    SENDING:&nbsp;&nbsp; User-Agent: ddclient/3.8.3
    SENDING:&nbsp;&nbsp; Connection: close
    SENDING:&nbsp; &nbsp;
    RECEIVE:&nbsp; HTTP/1.1 200 OK
    RECEIVE:&nbsp; Content-Type: text/html
    RECEIVE:&nbsp; Server: DynDNS-CheckIP/1.0
    RECEIVE:&nbsp; Connection: close
    RECEIVE:&nbsp; Cache-Control: no-cache
    RECEIVE:&nbsp; Pragma: no-cache
    RECEIVE:&nbsp; Content-Length: 106
    RECEIVE: &nbsp;
    RECEIVE:&nbsp; <html><head><title>Current IP Check</title></head><body>Current IP Address: *********</body></html>
    DEBUG:&nbsp;&nbsp;&nbsp; get_ip: using web, http://checkip.dyndns.org/ reports  *********
    SUCCESS:&nbsp; now0930.tk: skipped: IP address was already set to  *********.
    
  • matplotlib를 터미널 환경에서 사용하기

    집에 있는 서버에 tensorflow가 설치되어 있는데, ssh로 접속하여 실행한다. 결과물이 텍스트같이 터미널로 표시되면 볼수 있는데 그림으로 표시되면 터미널에 표시가 안된다.

    Traceback (most recent call last):
      File "imagetran.py", line 13, in <module>
        plt.imshow(image)
      File "/home/now0930/anaconda2/envs/tensorflow/lib/python2.7/site-packages/matplotlib/pyplot.py", line 3010, in imshow
        ax = gca()
      File "/home/now0930/anaconda2/envs/tensorflow/lib/python2.7/site-packages/matplotlib/pyplot.py", line 928, in gca
        return gcf().gca(**kwargs)
      File "/home/now0930/anaconda2/envs/tensorflow/lib/python2.7/site-packages/matplotlib/pyplot.py", line 578, in gcf
        return figure()
      File "/home/now0930/anaconda2/envs/tensorflow/lib/python2.7/site-packages/matplotlib/pyplot.py", line 527, in figure
        **kwargs)
      File "/home/now0930/anaconda2/envs/tensorflow/lib/python2.7/site-packages/matplotlib/backends/backend_qt4agg.py", line 46, in new_figure_manager
        return new_figure_manager_given_figure(num, thisFig)
      File "/home/now0930/anaconda2/envs/tensorflow/lib/python2.7/site-packages/matplotlib/backends/backend_qt4agg.py", line 53, in new_figure_manager_given_figure
        canvas = FigureCanvasQTAgg(figure)
      File "/home/now0930/anaconda2/envs/tensorflow/lib/python2.7/site-packages/matplotlib/backends/backend_qt4agg.py", line 76, in __init__
        FigureCanvasQT.__init__(self, figure)
      File "/home/now0930/anaconda2/envs/tensorflow/lib/python2.7/site-packages/matplotlib/backends/backend_qt4.py", line 68, in __init__
        _create_qApp()
      File "/home/now0930/anaconda2/envs/tensorflow/lib/python2.7/site-packages/matplotlib/backends/backend_qt5.py", line 138, in _create_qApp
        raise RuntimeError('Invalid DISPLAY variable')
    RuntimeError: Invalid DISPLAY variable
    

    마지막에 Invalid DISPLAY variable이라고 뜨고 죽는데 아래와 같이 변경하면 된다.

    import matplotlib
    matplotlib.use('Agg')
    
    import tensorflow as tf
    import matplotlib.image as mpimg
    import matplotlib.pyplot as plt
    
    # First, load the image
    filename = "./MarshOrchid.jpg"
    image = mpimg.imread(filename)
    
    # Print out its shape
    #print(image.shape)
    
    
    plt.imshow(image)
    plt.savefig('test.jpg')
    
    
    # Create a TensorFlow Variable
    x = tf.Variable(image, name='x')
    model = tf.initialize_all_variables()
    with tf.Session() as session:
    	x = tf.transpose(x, perm=[1, 0, 2])
    	session.run(model)
    	result = session.run(x)
    print(result.shape)
    mpimg.imsave('test.jpg',image)
    mpimg.imsave('test.jpg',result)
    

    디스플레이가 있는 PC에서 다운로드해 보면 된다..이게 웹으로 보내면 좋은데, 아직 그런게는 없나보다. stack overflow의 여기에서 답을 얻었다.

    질문은..
    Generating a PNG with matplotlib when DISPLAY is undefined

    시스템에 따라 설정파일을 바꾸면 귀찮게 안써도 되는데, 나의 경우 어디에 설정파일이 있는지 몰라 그냥 써야겠다.

  • 정해진 미래, 조영태

    정해진 미래, 조영태

    정해진 미래, 조영태
    isbn : 9791187289067

    얼마전 이진우의 손에에잡히는 경제에서 조영태 교수가 나와서 한국의 인구구조에 대해서 인터뷰를 했었다. 그때 한국의 미래를 인구 분포의 통계적인 분석을 근거로 예측했다. 교수가 말하는 내용이 대충 맞아 보였다. 또한 전에 누군가가 청년들이 줄고 있어 부동산은 하락한다고 주장했는데,그 내용이 맞을것인가가 궁금했다. 인터뷰 마지막에 자신이 쓴 책을 사라고 낚여서 하나 샀다.

    아쉬운 점은 최근에 출판된책인데 e-book으로 출판되지 않아 무거운 책을 들고 비행기를 탔다. 이와 별개로 과거 나왔던 cosmos도 하나 샀는데, 이 역시 e-book으로 발행되지 않았다. 첨부된 사진때문에 종이책으로 발간한듯 한데 상당히 아쉬운 부분이다. 전자책이 많이 활성화 되었으면 한다.

    머리말에 이 책의 목표가 간략하게 설명되어 있다. 향후 10년~15년 후에 한국의 인구구조가 변하는데, 더 늦기전에 대응을 잘해서 잘 살아보자이다. 제목은 “정해진 미래”인데, 부제는 이렇게 지어도 될것 같다. “줄어드는 인구, 잘살수 있는 기회”

    과거, 현재의 문제점을 인구학의 도구로 분석하여 설명했다. 현재 한국인구는 확실하게 줄어드는데, 정부는 이를 인정하지 않고 대책을 세웠고, 저자는 이를 비판한다. 높아지지 않는 출산률을 억지로 높이지 말고, 앞으로 줄어들 인구에 대비하여 현실적인 정부 대책을 요구한다. 마지막에는 변하는 한국에서 인구학의 도구로 어느정도 예측이 가능한데 이를 미래 생존전략으로 잘 살아야 된다고 독자들에게 주문한다.

    대충 이런 내용이고 나의 10, 15년후를 인구학을 적용해 보겠다. 10년, 15년 후에는 우리 애들은 16살, 21살이다. 나는 47살, 52살이고. 무엇을 하면 좋을지는 모르겠으나, 무엇을 하면 안될것은 확실하게 알수있다. 저자도 주장했지만 교육과 관련된 일들, 부동산 관련 업종이다. 아이들이 이런방향으로 한다고 하면 논리적으로 설명을 해줘야겠다. 게다가 얼마전에 30평대 집을 샀는데, 아이들이 어느정도 수준이 되면 더 늦기전에 팔아야 될것 같다.

    그럼 무엇을 해야 이득일까? 책에서는 딱히 없었지만, 아마 인건비를 줄이기 위한 기업들의 처절한 혁신이 있을 것이다. 10년 후, 기업의 대부분의 노동자 및 기술자들이 퇴직하고, 20~30대가 그 자리를 대체하겠다. 그러나 그 숫자는 많이 줄어든다. 기업들이 국내에서 생산시설을 유지하기 위해서는 해외생산 대비 이득이 있어야 한다. 기업은 이런 인력들을 채용하겠다. 과거 산업혁명에서 영국이 인도와 경쟁해서 이긴 이유는 인도의 값싼 노동력을 극복하기 위한, 영국의 기술혁신 때문이다. 앞으로 한국에 이런 현상이 재현될 것이라 생각된다.

    이를 위해서는 학교 교육에 만족하지 않고, 개방적인 사고를 할 필요가 있다. 틀에갇힌 입시 교육으로는 자유로운 생각을 할 수 없다. 아이들이 도서관의 책들을 쉽게 접할 수 있고, 자유롭게 상상할 수 있는 여유를 주는게 미래를 위한 투자라 생각된다.

    자신이 하고싶은 일을 찾는것도 중요하다. 요즘은 누구나 대학 교육에 저렴한 비용으로 접근할 수 있다. 내가 고등학교 다니던 시절과 많이 달라졋다. 과거 중학교때 터보C 책을 봤었는데, 정보의 접근도 제한되어 있었다. 더 큰 문제는 예제코드가 없어 테스트를 잘 해보지 못해 이해학 힘들었다. 지금은 많이 달라졌다. 누구나 코드를 개방할 수 있고, 다른 사람의 코드를 볼 수 있다. 이런 소프트웨어를 조작하는 능력은 미래사회에 가성비 향상의 큰 이점이 된다.

    나는 아마 10년뒤면 자의반, 타의반 제2의 인생을 준비하고 있겠다. 아직까지 우리 회사는 고령자?에 대한 퇴직 압박은 없는 편인데, 10년뒤에도 그럴지는 모르겠다. 그때 생산시설?이라고 할 수 있는 경제적 수단이 없으면 많이 피곤하다. 그래서 주식을 모으고 있는데, 아마 노인층을 상대하는 회사의 주식도 몇주 사야될것 같다. 그때까지 한국 노인들이 가난하면 안되는데, 걱정이다. 지금 중장년층들은 부동산에서 나오는 수입의 많이 의존하는 듯이 보인다. 부동산 가격이 떨어진다면, 그들의 수입도 줄어들텐데, 더 가난할 듯 보인다. 그렇다면 아마 주식밖에 없어 보인다.

    외국에서 제 2의 인생에 도전하는 것도 괜찮아 보인다. 애들을 다 키웠으니 국내에 걸릴것은 없고, 경력을 살려 도전하는 것도 건강한 삶을 사는데 도움이 될것이다.

    앞으로 무슨일이 있을지 머리아픈데, 이런 고민이 없다면 재미가 인생이 재미가 없을듯 하다. 그나저나, 주식이 좀 올라야 되는데 오를 기미가 안보인다…

  • 우분투+LEGO NXT(Lejos)를 eclipse로 bluetooth로 연결하기

    우분투+LEGO NXT(Lejos)를 eclipse로 bluetooth로 연결하기

    전에 우분투에 lejos가 깔린 lego nxt를 eclipse로 연결을 해서 파일 전송을 했었는데, 간만에 하니 시간이 좀 걸렸다. 이번에 정리한다..

    먼저 ubuntu의 bluetooth 모듈을 상태를 알아야 된다..

    >hcitool dev
    Devices:
    hci0 00:1A:7D:DA:71:02

     

    다음에 hci0의 상태를 알아낸다.

    >hciconfig hci0
    hci0: Type: BR/EDR Bus: USB
    BD Address: 00:1A:7D:DA:71:02 ACL MTU: 310:10 SCO MTU: 64:8
    UP RUNNING PSCAN ISCAN
    RX bytes:15110 acl:283 sco:0 events:1300 errors:0
    TX bytes:41343 acl:1147 sco:0 commands:88 errors:0

     

    나의 경우에는 bluetooth 동글이 usb로 연결되어 있다..

    다음에 nxt의 블루투스 모듈의 주소를 알아낸다.

    >hcitool scan
    Scanning ...
    00:16:53:12:7A:83 NXT

     

    이를 바탕으로 /etc/bluetooth/rfcomm.conf 파일을 아래와 같이 수정한다.

    >sudo cat /etc/bluetooth/rfcomm.conf
    #
    # RFCOMM configuration file.
    #
    
    rfcomm0 {
    # Automatically bind the device at startup
    bind no;
    
    # Bluetooth address of the device
    device 00:16:53:12:7A:83;
    
    # RFCOMM channel for the connection
    channel 1;
    
    # Description of the connection
    comment "LegoNXT";
    }

     

     

    다음에 아래의 명령어로 연결한다.

    >sudo rfcomm connect /dev/rfcomm0 00:16:53:12:7A:83 1
    Connected /dev/rfcomm0 to 00:16:53:12:7A:83 on channel 1
    Press CTRL-C for hangup

    CTRL-C로 연결을 끊어주고..eclipse로 연결하면 된다…

    nxt로 연결이 되었는지, 아닌지는 아래 명령으로 확인이 가능하다.

    >sudo l2ping 00:16:53:12:7A:83
    Ping: 00:16:53:12:7A:83 from 00:1A:7D:DA:71:02 (data size 44) ...
    4 bytes from 00:16:53:12:7A:83 id 0 time 26.82ms
    4 bytes from 00:16:53:12:7A:83 id 1 time 64.92ms
    4 bytes from 00:16:53:12:7A:83 id 2 time 24.87ms
    4 bytes from 00:16:53:12:7A:83 id 3 time 73.89ms
    4 bytes from 00:16:53:12:7A:83 id 4 time 34.89ms
    4 bytes from 00:16:53:12:7A:83 id 5 time 25.89ms
    4 bytes from 00:16:53:12:7A:83 id 6 time 76.82ms
    

     

    eclipse로 아래와 같이 설정 후, 연결하면 된다.
    eclipse%ec%84%a4%ec%a0%95%ed%99%94%eb%a9%b4

    eclipse에서 에러를 뿜어내는데 bluecove 어쩌고 나온다..

     >sudo apt-get install libbluetooth-dev

     

    이렇게 관련 프로그램을 설치하면 된다.

    KDE의 경우, PIN 입력이 안되는데, bluez-simple-agent로 연결하면 된다.

    bluez-simple-agent hci# xx:xx:xx:xx:xx:xx

    출처는 인터넷…

  • 오산 Air Power Day

    오산 Air Power Day

    Sorry you have no rights to view this post!