흐음.. 맥을 쓰다 보니깐... 맥에서 지원되는 포멧인 exFAT로 외장하드를 포멧했었다. 

그러다 보니 급 문제가 생긴것이 SynologyNAS에 백업하려고 했드만... 바로 마운트가 안되네...

급하게.. 방법을 찾아봤다. 

1. ntfs 는 마운트 하는 명령어가 동작하는데... 그것으로는 exFAT 마운트가 안된다. 

ntfs-3g /dev/sata2p1 /volume1/ADD1

2. 그래서 급하게 설치를 했다. 

#!/bin/sh

wget -P /tmp/ http://ftp.de.debian.org/debian/pool/main/f/fuse-exfat/exfat-fuse_1.3.0-2_amd64.deb

dpkg -x /tmp/exfat-fuse_1.3.0-2_amd64.deb /tmp/exfat-fuse/

cp /tmp/exfat-fuse/sbin/mount.exfat-fuse /usr/bin/

위처럼 설치용 shell을 하나 만들어서 돌려주고...  다음과 같은 방법으로 마운트를 해준다. 

# mount.exfat-fuse /dev/sata2p1 /volume1/ADD1

 

 

뭐 당연한 이야기 겠지만... sudo 권한 필요하고, nas에 ssh 활성화 시켜서 terminal 접근 가능해야 겠고....

백업 끝나면, "umount {$mount_path}" 로 마운트 해제하면 되겠고....

 

아.. hdd 정보 어떻게 찾았냐고??? "blkid" 명령어 치면 됨....

2021.04.23 금요일 날씨... 젖과꿀이 흐르는 듯한 흐린날씨.. 겁나좋다... (야발... 내 마음과도 같구나...)

 

엄청 예전에 action cam을 구매해서 잘 쓰고 있었다. 그 이름도 영롱한 짭프로 SJ4000

내가 구매하던 당시만 해도 국내 판매대행사가 없었었지...

 

근데... 개인적으로 일이 생기고, 액션캠을 쓸 일이 없어지게 되자... 액션캠은 장농속에서 썩고 있드라...

난 장롱청소도 가끔 하긴 하는데.... 뭔가 애처러워서....

그러다가 이직한 회사에서 코로나시국을 맞아서 재택근무를 시켜주기 시작하는데...

난 웹캠 없는데...

맥북에어 캠은 화질구지던데....

그러다가 급 생각이 나서....

근데... 아... 웹캠이 안되드라...(mac 이라 안되는 것인줄 알고, 드라이버 겁나 찾아봤는데... 남들은 잘만 쓰구 있드라...)

SJ4000 이라고 짭프로로 통하는... (내껀 no-wifi 버전이다... 왜냐구.. 와잎이없어...없...ㅇ.ㅇ.....ㅇㅁㅇ;;;;; )

 

암튼... 그래서... 급하게 펌웨어 업데이트를 받기 위해서 펌웨어를 구했지...

(출처) https://sjcam.com/community/forums/sj4000-series.56/

 

SJ4000 Series

 

sjcam.com

파일이 잘 사라지므로.. 일단 파일을 먼저 올리기도 한다. 

FW96650A.bin
2.60MB

이건 좋은데... 업데이트가 되고나니... 음??? 응???

웹캠으로써는 동작하드라...!!!!! (이게 중요한 사실이지...)

 

근데  대신 버튼이 아주 그냥 주옥처럼 변했다. 

ok 버튼은 동작을 안하고, 줌인은 되는데.. 줌아웃은 안되고, 줌아웃버튼이 ok로 동작한다.... 

 

 

오메.. 지쟈스... 하면서..

원복을 위해서.. 다시금 파일을 급하게 구해본다. 

FW96650A (1).bin
2.40MB

근데말야...

원래 내 목적은 액션캠을 쓰는게 아니라... 웹캠으로 쓰자는 거였잖아....

원복처리 했다가 결국 다시 펌웨어 설치하는 나를 발견했다.....

그리고...

그래서.. 다시 펌웨어를 설치하도록 했다...

 

아.. 펌웨어 설치는 간단하다. 

sd카드 root에 위에 파일을 살포시 복사해 놓고 sj4000 전원을 넣으면 알아서 펌웨어 업데이트 된다. 

 

업데이트 끝나면 꼭 sdcard에서 해당 bin 파일 지워주자.. 무한 펌웨어 업데이트를 하시드라.... 쩝....

 

오늘의 재택근무 뻘짓이었다.....

내가 처음 샀을때부터 이렇게 나왔어야지....

 

업데이트를 하면 로고가 기존과 다르게 바뀐다....

 

 

 

 

centos 최신버전을 설치할 일이 생겼다. 

장비는 장만했고, centos 8 도 설치가 되었다. 

그럼 설치를 한번 해볼까?

0. 버전 확인

$ cat /etc/*-release
CentOS Linux release 8.1.1911 (Core)
NAME="CentOS Linux"
VERSION="8 (Core)"
ID="centos"
ID_LIKE="rhel fedora"
VERSION_ID="8"
PLATFORM_ID="platform:el8"
PRETTY_NAME="CentOS Linux 8 (Core)"
ANSI_COLOR="0;31"
CPE_NAME="cpe:/o:centos:centos:8"
HOME_URL="https://www.centos.org/"
BUG_REPORT_URL="https://bugs.centos.org/"

CENTOS_MANTISBT_PROJECT="CentOS-8"
CENTOS_MANTISBT_PROJECT_VERSION="8"
REDHAT_SUPPORT_PRODUCT="centos"
REDHAT_SUPPORT_PRODUCT_VERSION="8"

CentOS Linux release 8.1.1911 (Core)
CentOS Linux release 8.1.1911 (Core)

1. Docker 설치 

1-1. yum update

$ sudo yum update

1-2. docker 설치 및 docker-compose 설치

$ sudo yum install docker-ce-18.06.3.ce-3.el7
$ sudo curl -L https://github.com/docker/compose/releases/download/1.25.0/docker-compose-`uname -s`-`uname -m` -o /usr/local/bin/docker-compose
$ sudo chmod 755 /usr/local/bin/docker-compose

1-3. activate docker by systemctl

$ sudo systemctl enable docker 
$ sudo systemctl start docker 
$ sudo systemctl is-activate docker

1-4. check docker

$ sudo docker ps -a

1-5. 유저 추가

docker를 사용할 때 항상 root 계정이 필요하다면, 사용이 불편하기도 하고, 관리도 용이하지 않은 관계로, docker 그룹에 내 계정을 추가하여 사용하도록 하자

$ sudo groupadd docker
$ sudo usermod -aG docker $USER
$ sudo reboot

 

아쉽게도 적용을 위해서는 서버를 재시작 해야 하드라.... 

갑자기 프로젝트를 하기 위해 파견을 나오게 되었다. 

할수 있는것은 아무것도 없고, 시스템 설계해 주시는 수석님과 나 둘이서 일단 프로젝트 하기 위한 준비를 해야만 한다. 

뭐... 어쩌겠는가.. 까라면 까는 IT 개발 종사자의 인생이란... 뭐... 하라면 해야지..

근데 수석님이 git을 싫어하신다고 한다. (하긴 안써보던거 쓰려면 힘드실 꺼야... 내가 이해하자. 그래 내가...)

이렇게 난 보살이 되어가고....

1. Docker 설치 

일단 프로젝트를 급하게 처리하기 위해 본사에서 놀고 있는 노트북에 ubuntu18.04.4 LTS를 최소버전으로 설치해서 준비하였다. 그럼 이제부터 설치를 해보도록 하자.

$ sudo apt-get install -y docker docker-compose

이번에 docker 설치할 때 docker-compose를 같이 설치하는 이유는 언제까지고 docker 실행파일을 .sh로 만들어서 관리할 수는 없잖아.... (귀찮아귀찮아)

 

2. yona와 mariadb를 한번에 설치

사실 yona나 mariadb는 os에 그냥 설치해도 된다. 근데 프로젝트하다가 장비가 없어질 수도 있고... 인생사는 어떻게 될지 모르는 거잖아... 

가끔씩 백업도 해주고 그래야 회사 자산이 될텐데... (지금 다니는 회사는 그런거에 대한 개념이 희박하다... 정말 파견전문업체....)

그렇다면 개발자라도 백업을.... 쿨럭...

일단 docker-compose도 깔았겠다. docker-compose.yml을 준비해 보자.

docker-compose.yml
version: '3.1'
services:
  yona-mariadb:
    image: witbox/yona-mariadb-10.2-bionic
    container_name : yona-mariadb
    restart: always
    networks:
    - yona
    environment:
      MYSQL_DATABASE: yona
      MYSQL_USER: yona
      MYSQL_PASSWORD: my_password 
      MYSQL_ROOT_PASSWORD: my_password
    ports:
    - "3306:3306"
    volumes:
    - /data/mysql:/var/lib/mysql

  yona:
    image: witbox/yona-1.12.0-alpine
    restart: always
    container_name : yona
    ports:
    - "9000:9000"
    - "465:465"   # smtp
    networks:
    - yona
    depends_on:
    - yona-mariadb
    environment:
      YONA_DATA : /yona/data
    volumes     :
    - /data/yona/data:/yona/data

  adminer:
    image: adminer
    container_name: yona_adminer
    restart: always
    networks:
    - yona
    ports:
    - 9001:8080
networks :
  yona :

개뿔 없다. 그냥 복사해서 붙여 넣으면 끝이다. 

사실 출처(https://repo.yona.io/yona-projects/yona/issue/50) 에서 준 파일로 그대로 한방에 되면 정말 좋겠지만.... 안되더라... 슬픈 현실이지.. 나두 안되서 이것저것 많이 시도해 봤으니까... 그래도 안되면 문의 남겼겠지만..... 일단 내가 해결해 봐야 시간이 잘가지.... (그리고 일하는 것처럼 보일라나???)

근데 개인적으로 내 패스워드는 나만 썼으면 좋겠다... 쫌.... 친절하게 굵은 글씨로 해놨으니... 제발 나랑 똑같이 쓰진 말자. 

이렇게 파일을 어떻게 만드느냐? 이것도 귀찮잖아. 그러니깐.... 내가 친절히 스크립트를 공유함. 

$ sudo mkdir -p /data/yona/data
$ sudo mkdir -p /data/mysql
$ sudo chmod 555 -R /data
$ cd ~ 
$ mkdir mariadb-yona
$ cd mariadb-yona
$ touch docker-compose.yml

요로코롬... 먼저 디렉토리를 준비해 주자. 

그리고 docker-compose.yml은 여기다가 만들어 주자. 

/data 디렉토리는 당신의 linux에 없을수도 있다... 참고하시고... 가능하면 스토리지 마운트 같은거 해서 쓰면... 좀더 os와 independent 하게 관리할 수 있지 않을까? (아 그러고 보니까.. mysql은 사고나면, lock 파일때문에 동작 안한다... 그건 알아서... 처리하도록하자...)

나머지 스크립트. 

$ sudo docker-compose up -d

3. 이제 잘 되면.... 당신은 이글을 찾지 않았겟지...ㅋ

맞다. 나도 여기서 또 안되더라...

어떻게 안되느냐? 바로 yona가 계속 restart 한다는 의미다. 

Docker에서 yona가 안뜨는 것은 다음을 통해 확인된다. 

$ sudo docker ps -a

뭐 안되는 이유는 알아야 조치를 할테니....

yona의 프로세스 로그를 확인하기 위해서 다음을 확인해 본다. 

$ tail -f /data/yona/data/logs/root.log

2020-03-25 11:36:27,021 - [ERROR] - from com.jolbox.bonecp.hooks.AbstractConnectionHook in main
Failed to obtain initial connection Sleeping for 0ms and trying again. Attempts left: 0. Exception: org.mariadb.jdbc.internal.util.dao.QueryException: Could not connect to address=(host=127.0.0.1)(port=3306)(type=master) : Connection refused (Connection refused).Message:Could not connect to address=(host=127.0.0.1)(port=3306)(type=master) : Connection refused (Connection refused)

나와 같은 로그가 나온다면... 그건... DB에 연결안된다는 의미인거지....

근데 DB 설정은 어디서 확인이 가능하느냐? 그건 /data/yona/data/conf/application.conf 에서 확인이 가능하다. 근데... 별 문제가 없어 보인다. 하지만... 이것을 해결하기 위해서는 다음을 기억해야 한다. 

이전에 mysql 시절 localhost 주소에 접근하기 위해서는 my.conf 파일을 변경했던 당신... 기억나는가? 

그때 기억은 나중에 검색하도록 하고.... 난 loopback 주소를 쓰지 않고, 직접 장비의 주소를 입력하는 것을 문제를 해결했다. 

/data/yona/data/conf/application.conf 

내 주소가 192.168.0.6 이다. 본인 pc의 ip는 직접 찾아 보시고... 나처럼 고쳐주면... docker yona는 알아서 restart 중이니... 알아서 재시작 하게 될 것이다. 근데 생각보다 초기 설정되는데 시간이 많이 걸리니깐... 안된다고 좌절하지 말고. 로그를 계속 지켜보자. 

 

4. 이렇게 설치가 완료되었다. 

정상적으로 yona가 구동되려면 docker yona를 재시작 해주어야 한다. 설마.... 

$ sudo docker restart yona

그렇다 당신은 이조차도 귀찮아 할 수 있으니.... 

 

이렇게 하고 관리자 설정 조금 해주면.... 또 안되겠지? 헤휴...

$ sudo ufw allow 9000

그렇다.... 방화벽....

방화벽 오픈 해주면... 대충 이제 사용이 가능할 것이다. 

내 글이 당신에게 도움이 되었으면 좋겠다. 

그리고 도움이 되었다면.. .댓글정도만이라도 남겨줘라... 인간적으로다가....

 

백수 생활한지 어언 1달이 넘어가고 있다.  
요즘 핫한 드라마는 역시 왕좌의 게임 시즌 8 
근데 집에 있는 pc에서 스마트tv로 당연히 미라케스트가 되겠지라고 생각했던 것중에 안되는 것이 생각보다 많이 있더라... 

특히 짜증 나는 것중에 하나인 mkv는 지원 안한다는 소리... 
그리고 자막 파일을 지원 안한다는 이야기는 왜이렇게 많은 것인지.....  

 그래서 오늘은 ffmpeg을 이용하여, 영상 파일 확장자를 변경하는 작업과 자막을 랜더링 처리한 컨텐츠를 만드는 것에 대해서 알아 보도록 하자... 

0. mkv to mp4

문제의 mkv 파일을 mp4로 변환해 보자.

일단 문제가 되는 것은 일반인(그냥 컨텐츠를 사용하는 유저) 입장에서는 영상이 어떻게 생겨 먹었는지 전혀 알 필요가 없다. 그냥 용량이 큰게 영상 품질도 좋겠지라고 생각한다.

하지만 생각보다 영상의 세계는 심오하여서... 귀찮게도 컨텐츠를 배포하는 업체(Content Delivery Network : CDN)나 컨텐츠를 제공하는 서비스(youtube, netflix, tving, 옥수수 등등등)에서는 영상을 품질별로 확인, 분류, 제공을 위한 매카니즘이 매년 새로운 것이 나온다고 볼 수 있을 정도로 다양하게 나온다.

각설하고....(뭔가 다 설명하려고 하니깐... 글이 엄청 길어질 것만 같은 느낌이 온다.)

영상이나 mp4로 변환하도록 하자. 

대충 보아하니, video는 h.264에 비트레이트가 약 7500kb/s 짜리 영상이다. 그리고 오디오가 eac3 구만...

역시 이런 영상은 미라캐스트 지원따윈 안되겠지.... 

미라캐스트가 지원되는 형태로 변환을 해 보도록 하자. 

>  ffmpeg -y -threads 6 -i input.mkv -vcodec copy -acodec aac input.mp4

본인의 pc는 옥타코어(엄청 예전에 샀던 발열의 신 비쉐라 되시겠다... (어후.. 거의 10년 쓰고 있는 느낌이야...)

어익후... 아직도 이런 pc 쓰는 사람이 바로 나야나!!!

그러니... 빠르게 영상을 편집하기 위해서는 불필요한 스트림에 대해서는 인코딩 하지 않고, 오디오만 인코딩을 하도록 하자.. (노친네같은 amd cpu를 분노케 하면, 백수 지갑이 매우 힘들어진다. )

대충 스크린샷 설명을 보면, Stream #0:0 은 video 부분으로 기존에 있는 h264 설정을 그대로 사용한다는 의미, Stream #0:1은 audio 부분으로 기본의 eac3 를 aac로 변경한다는 의미이다. 

일단 해당 설정으로 ffmpeg을 돌리면, h264, aac 를 가진 mp4 영상이 나오게 된다. 

재생 잘 되는지 확인해 보자...

> ffplay -vf subtitles=input.srt input.mp4

ffplay도 자막을 뿌려줄 수 있으니... 자막까지 한번에 확인해 보도록 하자. 

...더보기

 

잘... 재생됨... 그나저나 대너리스는 정말.......읍읍읍 (전 아무말도 안했습니다.)

(흠.. 귀찮으니.. 이 다음은.... 그만 알아보도록 하자....)

는 훼이크다..ㅋㅋㅋㅋ

 

 

 

 

1. smi to srt 파일 변환

 https://smisrt.com/

 

SRT SMI 자막 변환기

SRT SMI 미드 자막파일 검색자료 인코딩 편집, 속도 변환 다운로드 사이트

smisrt.com

일단 구한 자막 파일이 smi 파일인 것은 함정...

 자막파일 형태중에 너무 많이 쓰는 smi 파일 포멧 이지만, 사실 개발자 입장에서는 굉장히 피곤한 포멧이기도 하다. 내부 규격이 확정된 것이 없고, html 확장된 듯한 포멧이기 때문에 video randering 하는 플레이어가 어떻게 구현되었느냐에 따라 재생이 될때도 있고 안될때도 있는 파일 포멧이다. 

사람들이 많이 쓰거나, blue-ray, dvd에서 사용하는 포멧으로 살짝 변환을 해 보도록 해 보자. 

스크린샷 찍은것은 접어놓았으니... 펼쳐서 보시면 되시겠다. 

...더보기

 

1) 사이트에 접속후

 

2) 파일을 선택하고
3) smi->srt로 변환하기. 인코딩은 나와있는 거의 대부분의 smi 파일이 euc-kr이므로 utf-8로 변환해 준다.  자막에 싱크 조정이 필요한 경우에는 싱크조정을 설정해주고, 필요없는 경우 "0"을 적어주자
4) 하단에 변환해서 다운로드 버튼을 누르면, 처리 완료 (사이트를 어떻게 만들었는지 나중에 확인해 보도록 하자)

2. srt to ass

두번째 단계는 srt 파일을 ass 파일 포멧을 변환하는 과정이다.  .ass 파일 포멧으로 변환되어야 ffmpeg에서 자막을 영상에 입힐 수 있다. 

- ffmpeg 을 이용한 ass 포멧 변환

ffmpeg -i input.srt output.ass 

별건 없다.... 스크린샷 참고

 

3. encoding video

- ffmpeg을 이용하여 파일 생성.

ffmpeg -i INPUT.mp4 -vf subtitles=INPUT.SRT OUTPUT.MP4
...더보기

실행 예제 스크린샷이 없는것은 죄송. 

이렇게 만든 OUTPUT.MP4 파일을 가지고 smart-tv에서 미라캐스트를 이용하여 재생하면, 영상 잘 나옴. 

ps. (왜인지 모르겠으나, .ass 파일을 만들지 않아도 될 꺼 같은 느낌은 든다. 


1. 문제의 시작


잘 운용되고 있던 통계 로그 서버가 갑자기 먹통이 되었다. 

사실 전부 인수인계 되어있던 건데.... 갑자기 안된다는 메일이 한통 딱 날라왔다. 


뭔가 작업을 했으면 작업을 했었다... 그래서 안된다. 이런식으로 메일을 써 주면 좋으련만, 자기들 원하는 대로만 메일을 쓰지.....


일단 2월부터 통계 데이터가 없다고 하니, 해당 날짜부터 무슨 일이 있었는지 확인을 해보자..


2. 처음 보는 에러 로그

해당 로그는 다음과 같았다. 

sendBatchLog|HTTP Send error|sun.security.validator.ValidatorException: PKIX path building failed: sun.security.provider.certpath.SunCertPathBuilderException: unable to find valid certification path to requested target


흐음.. 느낌상으로는 https 로 통신하는데 문제가 있는것으로 보인다. 


3. https 통신 여부 확인하기. 


일단 os level에서 정상적으로 해당 데이터를 가지고 올 수 있는지 확인해 보았다. 

하지만 결과는 참담했다. 


1) 해당 장비에는 curl 이 깔려 있지 않았고, 

2) wget으로 페이지를 다운로드를 받으니, dns에서 해당 url을 찾을 수 없댄다. 

3) 게다가 apt-get으로 curl 같은 것을 다운로드 받을 수도 없다. 


일단 하나씩 해결해 보자. 


문제의 장비 정보

$ cat /etc/issue

Ubuntu 12.04.5 LTS \n \l


일단 apt-get을 사용할 수 있도록 해보자. 

기존에는 /etc/apt/source.list 에 ubuntu repository 주소가 다음과 같이 되어 있었다. 

http://kr.archive.ubuntu.com/ubuntu/

적절하게 백업뜨고 다음과 같이 변경해 주자. 


# cp /etc/apt/sources.list /etc/apt/sources.list.bak

# cat /etc/apt/sources.list | sed -e 's/http:\/\/kr.archive.ubuntu.com\/ubuntu\//http:\/\/ftp.daumkakao.com\/ubuntu\//g' > /etc/apt/sources.list


하지만 이게 잘 되면 얼마나 좋으련만....

dns 서버 문제가 있는것 같다. 

ftp.daumkakao.com을 못찾는다....


일단 static 으로 구성된 network환경을 확인해 보자


# vi /etc/network/interfaces

~

dns-nameservers 192.168.0.1

역시나 dns-nameservers 가 없다. 추가한 뒤에 파일을 수정해 준다. 

해주는 김에 /etc/resolv.conf 도 추가해 준다. 

# vi /etc/resolv.conf

# Dynamic resolv.conf(5) file for glibc resolver(3) generated by resolvconf(8)

#     DO NOT EDIT THIS FILE BY HAND -- YOUR CHANGES WILL BE OVERWRITTEN

nameserver 192.168.0.1

그 다음엔 깔끔하게 장비 reboot를 해 주자 

# reboot

reboot가 끝이 나고, 정상적으로 dns 서버가 동작하는 것을 확인했다. 

하는 김에 apt-get update 도 진행해줌

$ sudo apt-get update

잘 된다....


4. 문제의 서버에는 역시 접근이 안된다. 

https로 된 문제의 서버에는 self signed certificate 라는 이유의 에러 메시지를 뱉어내며 정상 동작을 하지 않는다... 

google 신의 도움으로 다음과 같이 업데이트를 진행해 준다. 

# update-ca-certificates -f

ref. http://manpages.ubuntu.com/manpages/cosmic/en/man1/c_rehash.1ssl.html


일단 wget, curl로 발생하던 에러는 드디어 사라졌다. 


5. java에서는 아직도 동일한 에러가 발생한다. 


이거가 뭔 일이냥? 

다시 또 검색을 해 보았다. 


ref. https://www.lesstif.com/pages/viewpage.action?pageId=12451848


상기 사이트에서 나온 결론은 다음과 같다. 

1) java keystore 상에 해당 CA 인증서 정보가 없다. 

2) 그렇기 때문에 https 사이트에 대해서 PKIX 에러가 발생되는 것이다. 

3) java default path에 있는 cacert에 문제의 인증서를 추가해 주자.


잘 정리하신 분이 계시길래.... 일단 따라해 보도록 한다. 


6. 변경 작업 시작


혹시라도 저 파일이 없어질 수도 있으니.. 다운을 받아봄..

InstallCert.java


$ curl -O https://gist.githubusercontent.com/lesstif/cd26f57b7cfd2cd55241b20e05b5cd93/raw/InstallCert.java

$ javac InstallCert.java

-bash: javac: command not found


아나... javac 이 없다고 합니다 그렇다면... 

심볼릭 링크를 걸어서 javac을 쓰도록 하자...

$ java -version

java version "1.8.0_161"

Java(TM) SE Runtime Environment (build 1.8.0_161-b12)

Java HotSpot(TM) 64-Bit Server VM (build 25.161-b12, mixed mode)

$ which java

/usr/bin/java

$ ll /usr/bin/java

lrwxrwxrwx 1 root root 26 Feb 19  2018 /usr/bin/java -> /opt/jdk1.8.0_161/bin/java

$ sudo ln -s /opt/jdk1.8.0_161/bin/javac /usr/bin/javac

$ javac InstallCert.java

음... 이제 돌아가는구만... 

그렇다면.. 문제의 사이트에서 인증서를 가져오도록 합니다. 


$ java -cp ./ InstallCert sample.kkus.com

Loading KeyStore /opt/jdk1.8.0_161/jre/lib/security/cacerts...

Opening connection to sample.kkus.com:443...

Starting SSL handshake...


javax.net.ssl.SSLException: java.lang.UnsupportedOperationException

        at sun.security.ssl.Alerts.getSSLException(Alerts.java:208)

        at sun.security.ssl.SSLSocketImpl.fatal(SSLSocketImpl.java:1959)

        at sun.security.ssl.SSLSocketImpl.fatal(SSLSocketImpl.java:1916)

        at sun.security.ssl.SSLSocketImpl.handleException(SSLSocketImpl.java:1899)

        at sun.security.ssl.SSLSocketImpl.startHandshake(SSLSocketImpl.java:1420)

        at sun.security.ssl.SSLSocketImpl.startHandshake(SSLSocketImpl.java:1397)

        at InstallCert.main(InstallCert.java:116)

Caused by: java.lang.UnsupportedOperationException

        at InstallCert$SavingTrustManager.getAcceptedIssuers(InstallCert.java:187)

        at sun.security.ssl.AbstractTrustManagerWrapper.checkAlgorithmConstraints(SSLContextImpl.java:1098)

        at sun.security.ssl.AbstractTrustManagerWrapper.checkAdditionalTrust(SSLContextImpl.java:1044)

        at sun.security.ssl.AbstractTrustManagerWrapper.checkServerTrusted(SSLContextImpl.java:986)

        at sun.security.ssl.ClientHandshaker.serverCertificate(ClientHandshaker.java:1596)

        at sun.security.ssl.ClientHandshaker.processMessage(ClientHandshaker.java:216)

        at sun.security.ssl.Handshaker.processLoop(Handshaker.java:1052)

        at sun.security.ssl.Handshaker.process_record(Handshaker.java:987)

        at sun.security.ssl.SSLSocketImpl.readRecord(SSLSocketImpl.java:1072)

        at sun.security.ssl.SSLSocketImpl.performInitialHandshake(SSLSocketImpl.java:1385)

        at sun.security.ssl.SSLSocketImpl.startHandshake(SSLSocketImpl.java:1413)

        ... 2 more


Server sent 3 certificate(s):


 1 Subject CN=sample.kkus.com, OU=InstantSSL, OU="Hosted by Korea Information Certificate Authority, Inc.", OU=IT, O=kkus Corporation, L="Bundang-gu, Seongnam-si", ST=Gyeonggi-do, C=KR

   Issuer  CN=COMODO RSA Organization Validation Secure Server CA, O=COMODO CA Limited, L=Salford, ST=Greater Manchester, C=GB

   sha1    72 54 e2 76 7e 5d 8a 64 92 48 81 b6 68 f1 14 ef 8b 95 6c 9a

   md5     ce 0a dd e9 20 c0 ea 57 07 5c 09 a8 64 8e 8f bb


 2 Subject CN=COMODO RSA Organization Validation Secure Server CA, O=COMODO CA Limited, L=Salford, ST=Greater Manchester, C=GB

   Issuer  CN=COMODO RSA Certification Authority, O=COMODO CA Limited, L=Salford, ST=Greater Manchester, C=GB

   sha1    10 4c 63 d2 54 6b 80 21 dd 10 5e 9f ba 5a 8d 78 16 9f 6b 32

   md5     91 29 73 32 12 d5 f5 65 18 64 d8 6b 7b ae 0b 98


 3 Subject CN=COMODO RSA Certification Authority, O=COMODO CA Limited, L=Salford, ST=Greater Manchester, C=GB

   Issuer  CN=COMODO RSA Certification Authority, O=COMODO CA Limited, L=Salford, ST=Greater Manchester, C=GB

   sha1    af e5 d2 44 a8 d1 19 42 30 ff 47 9f e2 f8 97 bb cd 7a 8c b4

   md5     1b 31 b0 71 40 36 cc 14 36 91 ad c4 3e fd ec 18


Enter certificate to add to trusted keystore or 'q' to quit: [1]

2

여기서 2를 선택한 이유는 문제의 사이트에서 CA 인증서만 필요하기 때문입니다. 

root 인증서를 집어 넣어도 되지만... 난 그냥.. 되기만 하면 되니깐, CA 인증서만.... 


[

[

  Version: V3

  Subject: CN=COMODO RSA Organization Validation Secure Server CA, O=COMODO CA Limited, L=Salford, ST=Greater Manchester, C=GB

  Signature Algorithm: SHA384withRSA, OID = 1.2.840.113549.1.1.12


  Key:  Sun RSA public key, 2048 bits

  modulus: ....

  public exponent: 65537

  Validity: [From: Wed Feb 12 09:00:00 KST 2014,

               To: Mon Feb 12 08:59:59 KST 2029]

  Issuer: CN=COMODO RSA Certification Authority, O=COMODO CA Limited, L=Salford, ST=Greater Manchester, C=GB

  SerialNumber: [    36825e7f b5a48193 7ef6d173 6bb93ca6]


Certificate Extensions: 8

[1]: ObjectId: 1.3.6.1.5.5.7.1.1 Criticality=false

AuthorityInfoAccess [

  [

   accessMethod: caIssuers

   accessLocation: URIName: http://crt.comodoca.com/COMODORSAAddTrustCA.crt

,

   accessMethod: ocsp

   accessLocation: URIName: http://ocsp.comodoca.com

]

]


[2]: ObjectId: 2.5.29.35 Criticality=false

AuthorityKeyIdentifier [

KeyIdentifier [

....

]

]


[3]: ObjectId: 2.5.29.19 Criticality=true

BasicConstraints:[

  CA:true

  PathLen:0

]


[4]: ObjectId: 2.5.29.31 Criticality=false

CRLDistributionPoints [

  [DistributionPoint:

     [URIName: http://crl.comodoca.com/COMODORSACertificationAuthority.crl]

]]


[5]: ObjectId: 2.5.29.32 Criticality=false

CertificatePolicies [

  [CertificatePolicyId: [2.5.29.32.0]

[]  ]

  [CertificatePolicyId: [2.23.140.1.2.2]

[]  ]

]


[6]: ObjectId: 2.5.29.37 Criticality=false

ExtendedKeyUsages [

  serverAuth

  clientAuth

]


[7]: ObjectId: 2.5.29.15 Criticality=true

KeyUsage [

  DigitalSignature

  Key_CertSign

  Crl_Sign

]


[8]: ObjectId: 2.5.29.14 Criticality=false

SubjectKeyIdentifier [

KeyIdentifier [

....

]

]


]

  Algorithm: [SHA384withRSA]

  Signature:

....


]


Added certificate to keystore 'jssecacerts' using alias 'sample.kkus.com-2'

좀 은밀한 것은 가렸음... 


이제 추출 작업은 끝났으니.... 파일이 제대로 있는지 확인


$ ls

InstallCert.class  InstallCert.java  InstallCert$SavingTrustManager.class  jssecacerts

일단 추출을 해 봅니다. 


$ keytool -exportcert -keystore jssecacerts -storepass changeit -file output.cert -alias sample.kkus.com-2

-bash: keytool: command not found

오 지쟈스... 

우울하구만... 또 symbolic link다 

$ sudo ln -s /opt/jdk1.8.0_161/bin/keytool /usr/bin/keytool

$ keytool -exportcert -keystore jssecacerts -storepass changeit -file output.cert -alias sample.kkus.com-2

Certificate stored in file <output.cert>


이 다음은 추출한 인증서를 java_root에 있는 인증서에 삽입

$ JAVA_HOME=/opt/jdk1.8.0_161

$ keytool -importcert -keystore ${JAVA_HOME}/jre/lib/security/cacerts -storepass changeit -file output.cert -alias sample.kkus.com-2

Certificate was added to keystore


이렇게 작업 후에 문제를 해결했음...

 ㅁ client side


#1. gen key


ssh-keygen -t rsa -C "comment_server_name"

Enter file in which to save the key (/home/user/.ssh/id_rsa): /home/user/.ssh/my_ssh_key # 키이름을 넣음

Enter passphrase (empty for no passphrase): ********** # 최초 등록시 사용할 비밀문구를 입력함


-t : 키타입 [ rsa | dsa ]

-C : 코멘트. 없어도 상관없음


/home/user/.ssh/id_rsa

/home/user/.ssh/id_rsa.pub

키파일이 생김. 생성된 키파일중 pub 키 파일을 서버에 등록하면 됨. 


#2. pubkey 파일 전송


scp /home/user/.ssh/id_rsa.pub user@{host}:/home/user/.ssh/t_id_rsa.pub


 ㅁ server side

#3. authorized_keys생성

cd /home/user/.ssh

cat t_id_rsa.pub >> ~/.ssh/authorized_keys


만약 authorized_keys 파일이 없다면 생성되겠지만, 바로 적용 안됨. 

chmod 644 ~/.ssh/authoized-keys


java path 설정 바꾸려다가 c:\ProgramData\Oracle\Java\javapath 디렉토리의 심볼릭 링크를 날려먹음

cygwin을 설치해서 사용중인 관계로 ln -s "hear" "target"을 했으나 안됨. 


해결 방안. 

> ni java.exe -i SymbolicLink -ta "C:\Java\jre8\bin\java.exe"


'IT > WINDOW' 카테고리의 다른 글

Window update uninstall  (0) 2014.08.20
WINDOW7 부트로더 이름 바꾸기  (0) 2012.09.17

갑자기 외우고 싶어졌다. 이유는 모르겠지만, 어렸을 적에 외운척 한거 말고, 진짜로 천자의 한자를 외워 보고 싶어졌다. 


어떻게 암기를 해야 할지를 모르겠기 땜쉬롱, 바보처럼 한번 외워보자. 


天地玄黃 宇宙洪荒 日月盈昃 辰宿列張 寒來暑往 秋收冬藏 閏餘成歲 律呂調陽

천지현황 우주홍황 일월영측 진숙열장 한래서왕 추수동장 윤여성세 율려조양


雲騰致雨 露結爲霜 金生麗水 玉出崑岡 劍號巨闕 珠稱夜光 果珍李柰 菜重芥薑

운등치우 노결위상 금생여수 옥출곤강 검호거궐 주칭야광 과진이내 채중개강


海鹹河淡 鱗潛羽翔 龍師火帝 鳥官人皇 始制文字 乃服衣裳 推位讓國 有虞陶唐

해함하담 인잠우상 용사화제 조관인황 시제문자 내복의상 추위양국 유우도당


弔民伐罪 周發殷湯 坐朝問道 垂拱平章 愛育黎首 臣伏戎羌 遐邇壹體 率賓歸王

조민벌죄 주발은탕 좌조문도 수공평장 애육여수 신복융강 하이일체 솔빈귀왕


鳴鳳在樹 白駒食場 化被草木 賴及萬方 蓋此身髮 四大五常 恭惟鞠養 豈敢毁傷

명봉재수 백구식장 화피초목 뇌급만방 개차신발 사대오상 공유국양 기감훼상


女慕貞烈 男效才良 知過必改 得能莫忘 罔談彼短 靡恃己長 信使可覆 器欲難量

여모정열 남효재량 지과필개 득능막망 망담피단 미시기장 신사가복 기욕난량


墨悲絲染 詩讚羔羊 景行維賢 克念作聖 德建名立 形端表正 空谷傳聲 虛堂習聽

묵비사염 시찬고양 경행유현 극념작성 덕건명립 형단표정 공곡전성 허당습청


禍因惡積 福緣善慶 尺璧非寶 寸陰是競 資父事君 曰嚴與敬 孝當竭力 忠則盡命

화인악적 복연선경 척벽비보 촌음시경 자부사군 왈엄여경 효당갈력 충즉진명


臨深履薄 夙興溫凊 似蘭斯馨 如松之盛 川流不息 淵澄取暎 容止若思 言辭安定

임심리박 숙흥온청 사난사형 여송지성 천류불식 연징취영 용지약사 언사안정


篤初誠美 愼終宜令 榮業所基 籍甚無竟 學優登仕 攝職從政 存以甘棠 去而益詠

독초성미 신종의령 영업소기 적심무경 학우등사 섭직종정 존이감당 거이익영


樂殊貴賤 禮別尊卑 上和下睦 夫唱婦隨 外受傅訓 入奉母儀 諸姑伯叔 猶子比兒

악수귀천 예별존비 상화하목 부창부수 외수부훈 입봉모의 제고백숙 유자비아


孔懷兄弟 同氣連枝 交友投分 切磨箴規 仁慈隱惻 造次弗離 節義廉退 顚沛匪虧

공회형제 동기연지 교우투분 절마잠규 인자은측 조차불리 절의염퇴 전패비휴


性靜情逸 心動神疲 守眞志滿 逐物意移 堅持雅操 好爵自縻 都邑華夏 東西二京

성정정일 심동신피 수진지만 축물의이 견지아조 호작자미 도읍화하 동서이경


背邙面洛 浮渭據涇 宮殿盤鬱 樓觀飛驚 圖寫禽獸 畵綵仙靈 丙舍傍啓 甲帳對楹

배망면낙 부위거경 궁전반울 누관비경 도사금수 화채선령 병사방계 갑장대영


肆筵設席 鼓瑟吹笙 陞階納陛 弁轉疑星 右通廣內 左達承明 旣集墳典 亦聚群英

사연설석 고슬취생 승계납폐 변전의성 우통광내 좌달승명 기집분전 역취군영


杜藁鍾隸 漆書壁經 府羅將相 路俠槐卿 戶封八縣 家給千兵 高冠陪輦 驅轂振纓

두고종례 칠서벽경 부라장상 노협괴경 호봉팔현 가급천병 고관배련 구곡진영


世祿侈富 車駕肥輕 策功茂實 勒碑刻銘 磻溪伊尹 佐時阿衡 奄宅曲阜 微旦孰營

세록치부 거가비경 책공무실 늑비각명 반계이윤 좌시아형 엄택곡부 미단숙영


桓公匡合 濟弱扶傾 綺回漢惠 說感武丁 俊乂密勿 多士寔寧 晋楚更覇 趙魏困橫

환공광합 제약부경 기회한혜 열감무정 준예밀물 다사식녕 진초갱패 조위곤횡


假途滅虢 踐土會盟 何遵約法 韓弊煩刑 起翦頗牧 用軍最精 宣威沙漠 馳譽丹靑

가도멸괵 천토회맹 하준약법 한폐번형 기전파목 용군최정 선위사막 치예단청


九州禹跡 百郡秦幷 嶽宗恒岱 禪主云亭 雁門紫塞 鷄田赤城 昆池碣石 鉅野洞庭

구주우적 백군진병 악종항대 선주운정 안문자새 계전적성 곤지갈석 거야동정


曠遠綿邈 巖峀杳冥 治本於農 務玆稼穡 俶載南畝 我藝黍稷 稅熟貢新 勸賞黜陟

광원면막 암수묘명 치본어농 무자가색 숙재남묘 아예서직 세숙공신 권상출척


孟軻敦素 史魚秉直 庶幾中庸 勞謙謹勅 聆音察理 鑑貌辨色 貽厥嘉猷 勉其祗植

맹가돈소 사어병직 서기중용 노겸근칙 영음찰리 감모변색 이궐가유 면기지식


省躬譏誡 寵增抗極 殆辱近恥 林皐幸卽 兩疏見機 解組誰逼 索居閑處 沈默寂寥

생궁기계 총증항극 태욕근치 임고행즉 양소견기 해조수핍 삭거한처 침묵적요


求古尋論 散慮逍遙 欣奏累遣 慼謝歡招 渠荷的歷 園莽抽條 枇杷晩翠 梧桐早凋

구고심론 산려소요 흔주누견 척사환초 거하적력 원망추조 비파만취 오동조조


陳根委翳 落葉飄颻 遊鵾獨運 凌摩絳霄 耽讀翫市 寓目囊箱 易輶攸畏 屬耳垣牆

진근위예 낙엽표요 유곤독운 능마강소 탐독완시 우목낭상 이유유외 속이원장


具膳飱飯 適口充腸 飽飫烹宰 饑厭糟糠 親戚故舊 老少異糧 妾御績紡 侍巾帷房

구선손반 적구충장 포어팽재 기염조강 친척고구 노소이량 첩어적방 시건유방


紈扇圓潔 銀燭煒煌 晝眠夕寐 藍筍象床 絃歌酒讌 接杯擧觴 矯手頓足 悅豫且康

환선원결 은촉위황 주면석매 남순상상 현가주연 접배거상 교수돈족 열예차강


嫡後嗣續 祭祀蒸嘗 稽顙再拜 悚懼恐惶 牋牒簡要 顧答審詳 骸垢想浴 執熱願凉

적후사속 제사증상 계상재배 송구공황 전첩간요 고답심상 해구상욕 집열원량


驢騾犢特 駭躍超驤 誅斬賊盜 捕獲叛亡 布射僚丸 嵇琴阮嘯 恬筆倫紙 鈞巧任釣

여라독특 해약초양 주참적도 포획반망 포사료환 혜금완소 염필륜지 균교임조


釋紛利俗 竝皆佳妙 毛施淑姿 工嚬姸笑 年矢每催 曦暉朗耀 璇璣懸斡 晦魄環照

석분리속 병개가묘 모시숙자 공빈연소 연시매최 희휘낭요 선기현알 회백환조


指薪修祐 永綏吉邵 矩步引領 俯仰廊廟 束帶矜莊 徘徊瞻眺 孤陋寡聞 愚蒙等誚

지신수우 영수길소 구보인령 부앙낭묘 속대긍장 배회첨조 고루과문 우몽등초


謂語助者 焉哉乎也

위어조자 언재호야

몇개씩 어떻게 외울지는.. 한번 생각해 보고...


3일차


4일차


5일차



notepad

wusa /uninstall /kb:2982791 
wusa /uninstall /kb:2970228
wusa /uninstall /kb:2975719
wusa /uninstall /kb:2975331

save uninstall.bat


uninstall.bat 실행


'IT > WINDOW' 카테고리의 다른 글

[Windows 10] 심볼릭 링크 만들기  (0) 2018.01.16
WINDOW7 부트로더 이름 바꾸기  (0) 2012.09.17

+ Recent posts