블로그 이미지
훅크선장

카테고리

분류 전체보기 (361)
사진이야기 (23)
펭귄컴퓨팅 (120)
컴퓨터보안 (84)
절름발이 프로그래머 (59)
하드웨어개조 (23)
멀알려줄까 (35)
홈베이킹&홈쿠킹 (2)
잡다한것들 (15)
Total
Today
Yesterday

달력

« » 2024.4
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

공지사항

태그목록

최근에 올라온 글

아파트 방들 사이에 사각지대가 있는데, 유선을 근처에서 끌어올 수 없는 상황이라서 Mesh 무선네트워크를 구축해보았는데,

기존의 유선 연결된 Dumb AP의 배치보다는 더 유연하게 전기만 끌어올 수 있으면 Mesh AP를 놓을 수 있어서 확실히 사각지대를 없애는 데는 좋은 방법 같다. 

그리고, 802.11r Fast Transition 까지 사용하면, 이동하면서 무선랜의 끊김 현상이 줄어들어서, 신기술 체험을 아주 잘 해보았다~!

 

첫번째 AP에서 할 일

1. wpad 패키지를 먼저 제거
기본 설치된 것은 wpad-basic-wolfssl

2. 새로운 wpad 패키지 설치
opkg update 한 다음에, wpad-mesh-openssl을 설치 한다.
그리고 바로 재부팅 한다. 반드시 재부팅

3. Network의 Wireless 로 이동하고, 
2.4G 밴드 또는 5G 밴드의 radio0/radio1 에서 Add 합니다.
(밴드 특성에 따른 선택, 예제에서는 2.4G를 선택함. 5G 대역은 무선랜 용으로만 사용)

Device Configuration 에서 채널을 선택하고,
아래도 내려와, Interface Configuration의 General Setup 에서
Mode :  802.11s
Mesh Id : my-mesh   적당한 것을 새로 작명
Network : lan  선택    mesh가 lan 영역에 연결된다.  mesh는 VLAN과 함께 쓸 수 없다.

Wireless security 에서 WPA3-SAE 를 선택하고, 비밀키를 선정하여 입력


두번째 AP에서 할 일
onemarc github에 가면, 한번에 처리할 수 있는 스크립트를 제공한다!!!
dumb AP 만드는 것과 매우 비슷하다.

0. 두번째 라우터와 첫번째 라우터를 연결하지 말고, 유선으로 두번째 라우터에 연결

1. LAN 인터페이스 수정 (Static Address로 할 수도 있으나, 쉽게 하기 위해서, Protocol DHCP client 로 설정
그리고, 첫번째 라우터와 두번째 라우터를 LAN to LAN 으로 연결 (90초 이내에)

2. 첫번째 라우터에서 두번째 라우터의 DHCP 주소를 확인하고,
두번째 라우터의 IP 주소로 GUI에 접근

3. Interfaces 로 가서, WAN과 WAN6 Delete 제거 한다.
Interfaces LAN으로 가서, Edit 누르고 Devices 탭으로 이동
br-lan 의 Configure 선택하고, Bridge ports 에서 wan을 추가해준다. 

4. System의 Startup 으로 가서, 
dnsmasq 과 odhcpd, Firewall 의 Enabled 버튼을 클릭해서, Disabled로 변경하고,
Stop 버튼을 눌러서, 서비스를 중지시킨다.

5. 이제 완전한 Dumb AP로 바꾸기 위해서, 첫번째 와 같이
1-3 과정을 수행한다. (wpad-basic 제거, wpad-mesh 설치, mesh 생성)
동일한 밴드와 채널로 설정된 것을 반드시 확인하세요.

이 과정을 마치면, Wireless의 Associated Stations에 Mesh Point가 반드시 나타나야만 합니다.
logread -f 로 상황 확인 가능

6. 두 라우터 사이의 유선 연결을 제거하고, ping 테스트를 수행한다.
(라우터의 재부팅 이후의 상황도 동일한지를 확인할 필요가 있다.)

7. 첫번째 라우터의 LAN mesh에 두번째 라우터가 가입된 상황이다. 이제 무선랜을 생성한다.
첫번째 라우터에서 2.4G 밴드에 mesh 포인트를 생성했다면, 5G 밴드에 wifi를 생성한다.

정상적인 무선랜을 설정하고, (밴드와 채널, 대역폭을 선택하고, 아래에서 무선보안에 관련된 암호화 기법과 비밀키 입력)

그리고, 802.11r Fast Transition을 체크한다.
Mobility Domain : 1234 (16진수 4자리로 선정)
FT protocol : FT over the Air 선택

8. 두번째 라우터에서도 무선랜을 생성하고 설정한다. (첫번째와 동일)

Posted by 훅크선장
, |

가상머신이 보편화된 요즘 IT 환경에서, 몇 년전에 만들었던 Live CD들이 쓸모가 있을까? 라는 생각이 들었지만...

그래도 만들어진 것들이 나름대로 의미가 있기에, FTP 서버를 복구하였습니다.

 

많은 ISO 파일들이 있으니, 한꺼번에 받지 마시고, 필요한 것만 받아가시기 바랍니다.

 

FTP 서버: hook7346.ignorelist.com

FTP 포트: 21번

FTP 계정: kali2ko

FTP 패스워드는 퀴즈입니다. => 영문자판상태에서 한글로 치시면 됩니다.

1) 패스워드는 한글 4글자와 특수문자 1개로 구성되어 있습니다.

2) 패스워드의 첫 두 글자는 우리나라 문자 이름입니다. 이미 1) 문장에서 나온 단어입니다.

3) 패스워드의 세번째와 네번째 두 글자는 3.1절에 외치던 문장에 있는 두 글자입니다.

“대한 독립 OO”에서 OO에 들어가는 단어입니다.

4) 마지막에 들어가는 특수문자는 3)의 단어뒤에 자주 붙는 특수문자입니다. 느낌이 오시나요? (이거 자주 헷갈리시는데, 쩜은 아닙니다. 느낌입니다.)

 

다시한번 말씀드리지만, 영문자판상태에서 한글로 치시면 됩니다.

한글 4글자와 특수문자 1개로 구성되어 있습니다.(영문자로는 총 12글자입니다.)

 

퀴즈가 안풀리시는 분은  아래 그림 화면에서 터미널창에 입력된 명령어를 주목하시면 됩니다.

--------------------------------------------------------------------------------------------------------------

 

Posted by 훅크선장
, |

준비사항 2가지 : 현재 컴퓨터에 Python3 설치하기 및 Telnet 프로그램 설치하기(준비하기)

※ Telnet 프로그램 설치하는 것이 만만치? 않아서, 요즘은 Netcat 프로그램을 Shell 모드로 사용하고 있다. 

    “nc -v 192.168.31.1 23” 명령어로 접속해서 쓰면 된다. 

 

사전 주의사항 :
공유기 판매 모델은 Xiaomi AX3200(모델 RB01, 국제 버전) 및 Redmi AX6S(모델 RB03, 중국 버전)의 두 가지 버전이 있다. 
두 버전 모두 정확히 동일한 하드웨어이지만, 유일한 차이점은 기본 펌웨어 버전(지역 잠금 여부)이 다르다는 것이다.

OpenWrt를 간단히 설치하려면 Telnet 기능이 필요한데, 문제는 일부 초기 생산 모델은 공장에서 텔넷이 활성화된 상태로 배송되었지만, 이후 장치는 대부분 텔넷이 비활성화된 상태로 배송되기 시작하여 OpenWrt를 쉽게 설치할 수 없게 되었다.
그러나 중국 버전 Redmi AX6S(모델 RB03)의 경우에는 telnet이 비활성화된 상태로 제공되더라도 기본 펌웨어(miwifi_rb03_firmware_stable_1.2.7_closedbeta.bin, 자세한 내용은 아래 참조)의 베타 버전을 설치하여 telnet 기능을 활성화할 수 있습니다. 이 베타버전 펌웨어는 Redmi AX6S(모델 RB03)에서 텔넷을 활성화하므로 OpenWrt 설치가 가능하게 할 수 있다.

 

※ 알리익스프레스에서 저렴한 중국 버전 Redmi AX6S(모델 RB03)을 구하는 것을 권장한다.
국제버전 Xiaomi AX3200(RB01 모델)인데, 공장에서 텔넷이 활성화되지 않은 경우에는 불행히도 UART 플래시 또는 "netmode: 4" 방법 외에는 텔넷을 활성화하는 알려진 방법이 없다. ㅠㅠ (많은 고난을 뚫고 펌웨어를 새로 설치할 지원자가 있는가??, UART 펌웨어 플래시는 상당히 과정이 복잡하다~!)

설치 단계:
0. 먼저 장비의 아래면에 있는 제품 라벨을 확인한다.  RB03 이라는 문자열을 확인한다. 
   가능하면, 그 옆쪽으로 장비의 시리얼넘버도 확인해서, 적어둔다. (SN: 으로 시작하는 뒤의 17자리 숫자와 글자이다.)


0. 아래 URL로 접근해서, 텔넷이 활성화되어 있는 것을 확인해보라~!
   http://192.168.31.1/cgi-bin/luci/api/xqsystem/fac_info

   아마도 아래와 같은 내용이 출력되며, 대부분 텔넷은 활성화되어 있지 않다!! ㅠㅠ

{"telnet":false,"init":false,"wl0_ssid":"xiaomi-router-rb03_miap951a_5G","ssh":false,"version":"1.0.37","facmode":false,"4kblock":false,"secboot":false,"wl1_ssid":"xiaomi-router-rb03_miap951a","uart":false}

 

1. 공유기를 인터넷에 연결하고, 중국어로 표시되는 화면에서 펌웨어 업로드 화면으로 진입한다.

현재 공유기에 인터넷을 연결하고, 추가적인 인터넷 회선이 없다면 작업용 노트북 또는 PC가 공유기에만 연결되어 있을 것이다.

추가적인 인터넷 회선이 있다면, 작업용 노트북 또는 PC를 직접 인터넷에 연결된 상태에서 중국어로 표시된 화면을 영어로 번역해서 볼 수 있을 것이다. 아래의 과정을 인터넷이 연결되지 않은 상태에서도 진행할 수 있도록, 중국어 화면과 영어 화면을 같이 표시한다.

 

1) 웹 브라우저로 http://192.168.31.1/ 공유기로 접속하면, 먼저 다음과 같은 화면이 표시된다.

화면 아래에 네모 체크박스 2개항과 아래에 버튼이 있다.

두개의 항은 각각 “사용자 라이선스 동의”와 “사용자 경험 개선 프로그램 가입”에 관련된 것으로 그냥 모두 체크하고, 아래 버튼을 눌러서 다음 단계로 진행하면 된다.  

※ 비록 사용자 관련 동의와 가입을 했더라도, 우리는 펌웨어를 완전히 교체하기 때문에 공유기의 정보가 향후 샤오미 회사에게 넘어갈 수가 없다.

2) 만약 공유기가 인터넷에 연결되어 있지 않다면, 다음의 화면이 표시된다. 

공유기의 WAN 포트를 반드시 인터넷 회선(DHCP)에 연결하여야 한다.  연결이 되었다면, 하단의 넓은 파란바 버튼을 눌러서 다음 단계로 진행한다.

 

3) 공유기가 인터넷에 연결되어 있으면, 바로 Internet Wizard 화면이 출력된다.

위에서부터 첫번째에는 슬라이드 옵션으로 무선 주파수 두 개를 동일한 모드로 운용할 지를 선택하는 것이고, 그 다음은 무선랜 Wi-Fi의 SSID와 비밀번호를 지정하는 곳이다. 이 두 가지는 지금 우리에게 꼭 필요하지 않지만, 그래도 설정한다.

무엇보다 Wi-Fi 비밀번호는 설정하여야 한다. 관리자 로그인 비밀번호로 사용하기 때문이다.

그 다음으로 네모 체크박스 2개항이 있다. 첫번째 항은 Wi-Fi 비밀번호를 관리자 암호로 같이 사용한다는 것이다. 반드시 체크하도록 한다.

그 다음 두번째 항은 최신 펌웨어를 자동으로 확인하여 업데이트하는 것인다. 우리에게 필요없는 것이다. 

요약) Wi-Fi 비밀번호를 설정하고, 첫번째 체크박스를 체크해준다. 그러면, Wi-Fi 비밀번호가 관리자 로그인 비밀번호가 된다. 

맨 하단의 버튼을 눌러서 다음으로 진행한다.

 

4) 앞에서 설정한 Wi-Fi의 SSID가 보이고, 임시로 내가 설정한 Passw-rd 라는 패스워드가 보인다.

 

5) 설정한 내용으로 공유기가 동작하는 상황이 표시된다. 이제 펌웨어 업데이트 화면으로 이동해야 한다. 

이 상태에서는 공유기를 통한 인터넷이 활성화 되어 있으므로, 구글 브라우저등을 통해서 페이지 번역이 가능할 것이다. 페이지 번역을 통해서 메뉴를 찾을 수 있지만, 중국어 메뉴에서 찾는 방법을 설명한다.

아래의 화면에서 상단 부분에 중국어 한자 네글자씩 세개가 보일 것이다. 이중에서 가운데 있는  “常用设置” 글자를 선택한다.

 

6) “常用设置” 글자가 선택되면, 그 아래에 5개의 동그란 아이콘이 보이는데, 그중에서 맨 오른쪽에 있는 영어 i 글자가 있는 오렌지색 동그라미를 선택한다. 오렌지색 동그라미를 선택하면 아래와 같은 화면이 보인다.

하얀 바탕 화면에서 세번째 줄에 보면, 1.0.37 과 같은  숫자가 보일 것이다. 그리고 그 아래에 회색 바탕에 직사각형 버튼이 보인다. (직사가형 버튼에 중국어 한자로 “手动升级”라고 쓰여 있다.) 바로 그 버튼을 누른다.  ※ manual upgrade 라는 의미이다.

 

7) 아래와 같이, manual upgrade를 위한 펌웨어 지정 다이얼로그가 나오면, “파일 선택” 을 눌러서 베타 펌웨어 파일을 지정하면 된다.

현재 여기에서 Redmi AX6(RB03 모델)인 경우, miwifi_rb03_firmware_stable_1.2.7_closedbeta.bin 베타 펌웨어를 아래의 링크에서 다운로드하고, “파일 선택” 에서 그 베타 펌웨어를 지정하면 된다.
https://github.com/YangWang92/AX6S-unlock/raw/master/miwifi_rb03_firmware_stable_1.2.7.bin
(MD5: 5eedf1632ac97bb5a6bb072c08603ed7)

8) miwifi_rb03_firmware_stable_1.2.7_closedbeta.bin 베타 펌웨어를 선택해서, 지정하면 아래와 같이 된다.

다이얼로그의 하단 파란색 버튼을 선택하여, 펌웨어 업그레이드를 진행시킨다.

 

9) manual upgrade 화면을 통해, 베타 펌웨어를 업로드하고 장비를 플래시하면, 아래와 같은 화면이 나오고 몇 분간 기다리는 시간이 필요하다.

 

10) 장비에 베타 펌웨어가 다 올라가면, 자동으로 아래와 같은 화면이 보일 것이다.

만약 자동으로 접속이 안된다면, 웹 브라우저에서  다시 192.168.31.1로 접속하면, 아래 화면이 보일 것이다.

QR코드 네모의 아래 빈칸에 이전 Internet Wizard 과정에서 지정한 Wi-Fi 비밀번호(로그인 암호)를 넣으면, 장비에 로그인된다.

 

11) 이전에서 했던 것과 같이, “常用设置” 글자를 선택하고, 화면에서 맨 오른쪽에 있는 영어 i 글자가 있는 오렌지색 동그라미를 선택한다.

하얀 바탕 화면에서 세번째 줄에 보면, 우리가 업로드한 베타 펌웨어 버전 번호 1.2.7 이라는 숫자가 보여야 한다.

1.2.7 버전의 베타 펌웨어가 정상적으로 업로드되었으므로, OpenWRT 펌웨어를 설치할 수 있는 환경이 되었다.

※ 1.2.7 버전 번호가 보이지 않는다면, 앞의 과정을 잘 반복해서 베타 펌웨어가 잘 설치될 수 있도록 한다.

 

3. 공유기의 환경 준비가 완료되었으므로,

https://github.com/YangWang92/AX6S-unlock/raw/master/unlock_pwd.py

에 있는 Python 프로그램 파일을 다운로드하고, unlock_pwd.py라는 이름으로 여러분의 컴퓨터 로컬 디스크에 저장한다. 그런 다음 커맨드창을 열어서, 다음 명령어줄의 <S/N>을 장비의 아래면에 있는 실제 시리얼 번호로 대체하여 실행한다. 
python3 unlock_pwd.py <S/N> 

위와 같은 형태로 명령을 실행하는데, 내 경우에는 
python3 unlock_pwd.py "36000/K1WW00000"
로 가능하면, “” 쌍따옴표를 이용해서 시리얼넘버를 둘러싸준다. (/ 특수문자 때문에 이렇게 한다.)

※ 인터넷 검색을 해서, 컴퓨터에 python3 를 먼저 설치해야만 한다.

이렇게 실행하면, 텔넷 접속을 위한 패스워드가 출력된다.
$ python3 unlock_pwd.py "36000/K1WW00000"
aeb5b9ac

 

4. 위 과정에서 확보된 패스워드 8자리 문자열을 가지고, telnet 으로 라우터 장비로 로그인한다.
$ telnet 192.168.31.1
Trying 192.168.31.1...
Connected to xiaoqiang.
Escape character is '^]'.

XiaoQiang login: root
Password: aeb5b9ac

 

BusyBox v1.25.1 (2021-10-25 11:02:56 UTC) built-in shell (ash)

 -----------------------------------------------------
       Welcome to XiaoQiang!
 -----------------------------------------------------
  $$$$$$\  $$$$$$$\  $$$$$$$$\      $$\      $$\        $$$$$$\  $$\   $$\
 $$  __$$\ $$  __$$\ $$  _____|     $$ |     $$ |      $$  __$$\ $$ | $$  |
 $$ /  $$ |$$ |  $$ |$$ |           $$ |     $$ |      $$ /  $$ |$$ |$$  /
 $$$$$$$$ |$$$$$$$  |$$$$$\         $$ |     $$ |      $$ |  $$ |$$$$$  /
 $$  __$$ |$$  __$$< $$  __|        $$ |     $$ |      $$ |  $$ |$$  $$<
 $$ |  $$ |$$ |  $$ |$$ |           $$ |     $$ |      $$ |  $$ |$$ |\$$\
 $$ |  $$ |$$ |  $$ |$$$$$$$$\       $$$$$$$$$  |       $$$$$$  |$$ | \$$\
 \__|  \__|\__|  \__|\________|      \_________/        \______/ \__|  \__|


root@XiaoQiang:~# 

 

5. OpenWrt 펌웨어를 설치하기 위한 준비과정으로 다음 명령을 차례로 실행한다.
root@XiaoQiang:~# nvram set ssh_en=1
root@XiaoQiang:~# nvram set uart_en=1
root@XiaoQiang:~# nvram set boot_wait=on
root@XiaoQiang:~# nvram set flag_boot_success=1
root@XiaoQiang:~# nvram set flag_try_sys1_failed=0
root@XiaoQiang:~# nvram set flag_try_sys2_failed=0
root@XiaoQiang:~# nvram set "boot_fw1=run boot_rd_img;bootm"
root@XiaoQiang:~# nvram commit

 

6.

https://downloads.openwrt.org/releases/22.03.2/targets/mediatek/mt7622/openwrt-22.03.2-mediatek-mt7622-xiaomi_redmi-router-ax6s-squashfs-factory.bin

컴퓨터에 다운로드한 openwrt-mediatek-mt7622-xiaomi_redmi-router-ax6s-squashfs-factory.bin 파일의 이름을 factory.bin으로 변경한다.
factory.bin 파일이 있는 동일한 디렉터리에서 새로운 커맨드 창을 열고, 다음 명령을 실행한다.
$ ll factory.bin 
-rw-r--r--@ 1 myname  staff  10485760 12  9 23:14 factory.bin
$ python3 -m http.server

Serving HTTP on :: port 8000 (http://[::]:8000/) ...
위와 같은 메시지가 출력되면,

다음, 다른 쪽의 텔넷 세션으로 이동해서 다음 명령어를 실행한다. 반드시 공유기에 연결된 현재 컴퓨터의 IP 주소를 먼저 확인해두어야 한다. 내 경우에는 192.168.31.234 이었다.

 

root@XiaoQiang:~# cd /tmp
root@XiaoQiang:/tmp# wget http://192.168.31.234:8000/factory.bin
Connecting to 192.168.31.234:8000 (192.168.31.234:8000)
factory.bin          100% |***********************************************************************************************| 10240k  0:00:00 ETA
root@XiaoQiang:/tmp# ls -la factory.bin
-rw-r--r--    1 root     root      10485760 Dec  9 22:20 factory.bin

공유기 쪽 세션에서 다운로드 받은 factory.bin 파일의 크기와 전송하는 쪽에서 확인한 파일의 크기를 확인한다. 꼭 제대로 확인한다.
펌웨어를 업로드한다.
root@XiaoQiang:/tmp# mtd -r write factory.bin firmware
Unlocking firmware ...

Writing from factory.bin to firmware ...     
Rebooting ...

잠시 대기한다. 한 1분 정도...

 

7. 공유기가 재부팅되면서, 컴퓨터 쪽의 IP 주소가 192.168.1.x 대역으로 바뀌면, 정상적으로 OpenWRT가 설치된 것이다.
웹브라우저로 192.168.1.1로 접근해서 확인한다. 패스워드 없이 그냥 로그인 하면 된다. 


먼저 system -> administration 으로 이동해서 패스워드를 설정하고, 그다음은 ssh 접근해서, 여러 패키지를 설치한다~!


$ ssh root@192.168.1.1
The authenticity of host '192.168.1.1 (192.168.1.1)' can't be established.
ED25519 key fingerprint is SHA256:FnxpFDIR5ay8gj2oDEcTD6dN8KiYOvfEnLZ4YUbGuXg.
This key is not known by any other names
Are you sure you want to continue connecting (yes/no/[fingerprint])? yes
Warning: Permanently added '192.168.1.1' (ED25519) to the list of known hosts.
root@192.168.1.1's password: 


BusyBox v1.35.0 (2022-10-14 22:44:41 UTC) built-in shell (ash)

  _______                     ________        __
 |       |.-----.-----.-----.|  |  |  |.----.|  |_
 |   -   ||  _  |  -__|     ||  |  |  ||   _||   _|
 |_______||   __|_____|__|__||________||__|  |____|
          |__| W I R E L E S S   F R E E D O M
 -----------------------------------------------------
 OpenWrt 22.03.2, r19803-9a599fee93
 -----------------------------------------------------
root@OpenWrt:~# 

 

root@OpenWrt:~# opkg update
Downloading https://downloads.openwrt.org/releases/22.03.2/targets/mediatek/mt7622/packages/Packages.gz
Updated list of available packages in /var/opkg-lists/openwrt_core
Downloading https://downloads.openwrt.org/releases/22.03.2/targets/mediatek/mt7622/packages/Packages.sig
Signature check passed.
Downloading https://downloads.openwrt.org/releases/22.03.2/packages/aarch64_cortex-a53/base/Packages.gz
Updated list of available packages in /var/opkg-lists/openwrt_base
Downloading https://downloads.openwrt.org/releases/22.03.2/packages/aarch64_cortex-a53/base/Packages.sig
Signature check passed.
Downloading https://downloads.openwrt.org/releases/22.03.2/packages/aarch64_cortex-a53/luci/Packages.gz
Updated list of available packages in /var/opkg-lists/openwrt_luci
Downloading https://downloads.openwrt.org/releases/22.03.2/packages/aarch64_cortex-a53/luci/Packages.sig
Signature check passed.
Downloading https://downloads.openwrt.org/releases/22.03.2/packages/aarch64_cortex-a53/packages/Packages.gz
Updated list of available packages in /var/opkg-lists/openwrt_packages
Downloading https://downloads.openwrt.org/releases/22.03.2/packages/aarch64_cortex-a53/packages/Packages.sig
Signature check passed.
Downloading https://downloads.openwrt.org/releases/22.03.2/packages/aarch64_cortex-a53/routing/Packages.gz
Updated list of available packages in /var/opkg-lists/openwrt_routing
Downloading https://downloads.openwrt.org/releases/22.03.2/packages/aarch64_cortex-a53/routing/Packages.sig
Signature check passed.
Downloading https://downloads.openwrt.org/releases/22.03.2/packages/aarch64_cortex-a53/telephony/Packages.gz
Updated list of available packages in /var/opkg-lists/openwrt_telephony
Downloading https://downloads.openwrt.org/releases/22.03.2/packages/aarch64_cortex-a53/telephony/Packages.sig
Signature check passed.
root@OpenWrt:~# 

 

한글 UI 패키지를 설치해준다. 
root@OpenWrt:~# opkg install luci-i18n-base-ko
Installing luci-i18n-base-ko (git-22.339.56129-deebfa0) to root...
Downloading https://downloads.openwrt.org/releases/22.03.2/packages/aarch64_cortex-a53/luci/luci-i18n-base-ko_git-22.339.56129-deebfa0_all.ipk
Configuring luci-i18n-base-ko.
root@OpenWrt:~# 

8. 이제 한글로 된 최신 OpenWRT의 모습을 보게 된다.

 

 

 

------ 참고 -------------------

※ Telnet 설치하는 것이 너무 귀찮아서, 요즘은 그냥 Netcat을 쉘모드로 쓰고 있다. 참고하시라~! 

 

Mac OS X 에서 HomeBrew로 Telnet 명령어 설치하는 방법

 

$ /bin/bash -c "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/HEAD/install.sh)"

==> Checking for `sudo` access (which may request your password)...
Password:
==> This script will install:
/opt/homebrew/bin/brew
/opt/homebrew/share/doc/homebrew
/opt/homebrew/share/man/man1/brew.1
/opt/homebrew/share/zsh/site-functions/_brew
/opt/homebrew/etc/bash_completion.d/brew
/opt/homebrew
==> The following new directories will be created:
/opt/homebrew/Caskroom

 

Press RETURN/ENTER to continue or any other key to abort:
==> /usr/bin/sudo /bin/mkdir -p /opt/homebrew/Caskroom
==> /usr/bin/sudo /bin/chmod ug=rwx /opt/homebrew/Caskroom
==> /usr/bin/sudo /usr/sbin/chown myname /opt/homebrew/Caskroom
==> /usr/bin/sudo /usr/bin/chgrp admin /opt/homebrew/Caskroom
==> /usr/bin/sudo /usr/sbin/chown -R myname:admin /opt/homebrew
==> Downloading and installing Homebrew...
remote: Enumerating objects: 914, done.
remote: Counting objects: 100% (376/376), done.
remote: Compressing objects: 100% (15/15), done.
remote: Total 914 (delta 363), reused 372 (delta 361), pack-reused 538
Receiving objects: 100% (914/914), 446.39 KiB | 2.40 MiB/s, done.
Resolving deltas: 100% (615/615), completed with 159 local objects.
From https://github.com/Homebrew/brew
   4abca3fa1..11cdffb4f  master              -> origin/master
 * [new branch]          setup-homebrew-test -> origin/setup-homebrew-test
 * [new tag]             3.6.13              -> 3.6.13
 * [new tag]             3.6.14              -> 3.6.14
HEAD is now at 11cdffb4f Merge pull request #14235 from Homebrew/dependabot/bundler/Library/Homebrew/json_schemer-0.2.24
Updated 1 tap (homebrew/core).
Warning: /opt/homebrew/bin is not in your PATH.
  Instructions on how to configure your shell for Homebrew
  can be found in the 'Next steps' section below.
==> Installation successful!

==> Homebrew has enabled anonymous aggregate formulae and cask analytics.
Read the analytics documentation (and how to opt-out) here:
  https://docs.brew.sh/Analytics
No analytics data has been sent yet (nor will any be during this install run).
==> Homebrew is run entirely by unpaid volunteers. Please consider donating:
  https://github.com/Homebrew/brew#donations
==> Next steps:
- Run these three commands in your terminal to add Homebrew to your PATH:
    echo '# Set PATH, MANPATH, etc., for Homebrew.' >> /Users/myname/.profile
    echo 'eval "$(/opt/homebrew/bin/brew shellenv)"' >> /Users/myname/.profile
    eval "$(/opt/homebrew/bin/brew shellenv)"
- Run brew help to get started
- Further documentation:
    https://docs.brew.sh

 

$ echo '# Set PATH, MANPATH, etc., for Homebrew.' >> /Users/myname/.profile
$ echo 'eval "$(/opt/homebrew/bin/brew shellenv)"' >> /Users/myname/.profile
$ eval "$(/opt/homebrew/bin/brew shellenv)"
$ brew help
Example usage:
  brew search TEXT|/REGEX/
  brew info [FORMULA|CASK...]
  brew install FORMULA|CASK...
  brew update
  brew upgrade [FORMULA|CASK...]
  brew uninstall FORMULA|CASK...
  brew list [FORMULA|CASK...]

Troubleshooting:
  brew config
  brew doctor
  brew install --verbose --debug FORMULA|CASK

Contributing:
  brew create URL [--no-fetch]
  brew edit [FORMULA|CASK...]

Further help:
  brew commands
  brew help [COMMAND]
  man brew
  https://docs.brew.sh

 

$ brew install telnet
==> Downloading https://ghcr.io/v2/homebrew/core/telnet/manifests/64
######################################################################## 100.0%
==> Downloading https://ghcr.io/v2/homebrew/core/telnet/blobs/sha256:cf76f3b47cf35efd4d271adf52227e463298005ec9b1ac586b629d5ad94522cf
==> Downloading from https://pkg-containers.githubusercontent.com/ghcr1/blobs/sha256:cf76f3b47cf35efd4d271adf52227e463298005ec9b1ac586b629d5ad94
######################################################################## 100.0%
==> Pouring telnet--64.arm64_monterey.bottle.tar.gz
🍺  /opt/homebrew/Cellar/telnet/64: 4 files, 175.2KB
==> Running `brew cleanup telnet`...
Disable this behaviour by setting HOMEBREW_NO_INSTALL_CLEANUP.
Hide these hints with HOMEBREW_NO_ENV_HINTS (see `man brew`).

Posted by 훅크선장
, |

https://www.libe.net/openwrt-devices

 

OpenWRT hardware recommendation - available devices 2022

OpenWRT provides a uniform and up-to-date software for different network devices like routers or access points and delivers countless additional setting options, software packages and functions. This makes it possible to combine new and old devices from d

www.libe.net

https://techsphinx.com/wireless/best-openwrt-router/

 

5 Best OpenWRT Routers in 2022

OpenWRT unlocks the hidden potential of your router and allows complete control over the device. Here's the list of the Best OpenWRT routers.

techsphinx.com

https://www.gadgetreview.com/best-openwrt-routers

 

Best OpenWRT Routers 2022 ~ Top Router Hardware For OpenWRT

To help you find the best OpenWRT routers, we first spent multiple hours determining which options would support the open-source software. After that, we

www.gadgetreview.com

https://blog.rottenwifi.com/best-router-for-openwrt/

 

5 Best Router For OpenWRT in 2022

Find out why I chose best router for OpenWRT and what are the benefits of choosing this one. Learn how you can set up your own open source wireless network and enjoy fast internet connection without paying a dime.

blog.rottenwifi.com

 

유투브나 인터넷에 best openwrt router 로 검색해서 추천한 제품을 여러 개 봤는데, 한국에서 구하기 힘들기도 하고,

가격대가 워낙 비싼 것들도 있다보니, (※ 현재 대부분 저렴한 공유기는 ac 까지만 지원하고, ax 제품은 가격이 10만원이 넘습니다. 시장에 ax 제품이 많지만, 아직 openwrt 지원하는 제품이 매우 희소하네요~!)

내가 직접 써본 제품들중에서 아마 최신과 최고 가성비는 Xiaomi Redmi AX6S 인 것 같습니다.

알리익스프레스에서 중국 내수용 버전을 6~8만원 정도에 구매할 수 있습니다.

펌웨어가 초반에 중국어로 나와서 약간 당황스럽기는 하지만, 그래도 최고의 가성비 인 것 같습니다.

 

장점: 

1. 싼 가격에 훌륭한 하드웨어 

2. 802.11ax (wifi 6)까지 지원하는 성능, 무선랜 거리 및 속도 매우 좋음 

 

단점:

1. 랜포트가 겨우 3개 (8포트 허브나  이전의 OpenWRT 하드웨어로 Dumb AP 만들어서 확장해야  함)

2. 자체에 USB 3.0 포트 없음 (OpenWRT 자체에 디스크 연결 확장 불가로  파일서버 운영이 불가, 별도 네트워크 서버나 NAS 장비 추가 필요)

3. 중국 내수용 펌웨어에서 OpenWRT 설치의 약간 어려움. (중국어 화면에서 펌웨어 업데이트를 한번 해줘야 하는데, 중국어를 못 읽으면, 무슨 말인지 몰라서...)

 

https://ko.aliexpress.com/wholesale?catId=0&initiative_id=SB_20221209092638&origin=y&SearchText=redmi+ax6s&spm=a2g0o.detail.1000002.0 

 

redmi ax6s - AliExpress 에서 redmi ax6s 구매하고 무료로 배송받자 version

 

ko.aliexpress.com

Posted by 훅크선장
, |

다른 사람이 공유해 준, 구글 드라이브의 대용량 파일을 끊김없이 안전하게 오랫동안 다운로드 하는 방법으로,

rclone 프로그램을 이용해봤다. 

Mac OS X 상에서 콘솔로 실행하다 보니, 아무래도 설정파일을 맞추기가 쉽지 않았다. 대충 때려 잡아서...

 

일단 rclone-v1.59.1-osx-amd64  버전을 다운로드 받아서, zip 압축을 풀었다.

./rclone --config hook.conf config 

명령으로 나만의 config 파일을 별도로 생성할 수 있다.

원래 기본 config 파일은 계정의 홈디렉토리 쪽  ~/.config/rclone/rclone.conf  에 있다.

 

https://vision4me.tistory.com/18

 

Rclone을 이용한 대용량 데이터 다운로드

얼마 전 기다리고 있던 데이터가 드디어 오픈되면서 대용량 데이터를 받을 일이 생겼다. 아직 일부분만 release 되었는데도 100기가가 넘는 데이터이다 보니 data 사이트에서도 rclone을 이용한 다운

vision4me.tistory.com

https://hjm79.top/rclone-mount/

 

rclone 윈도우 마운트하기 raidrive, google drive stream - 마니의 블로그

2022.7.19 현재 최신버전 1.59.0 버전 기준으로 수정하였습니다. 윈도우 Rclone 설정 윈도우 마운트와 자동으로 마운트 하기를 서비스에 등록하기입니다. https://hjm79.top/%ea%b5%ac%ea%b8%80-%ed%8c%80%eb%93%9c%eb%9

hjm79.top

위와 같이, 구글 드라이브를 접근 설정하고 나면(구글 웹브라우저 인증을 받고 나면), 기본 설정 파일이 생기는데, 그 안에 추가로 나만의 설정을 넣으면 된다.

[mygoogledrive]

type = drive

scope = drive

token = {"access_token":"...---...","token_type":"Bearer","refresh_token":"...---...","expiry":"2022-09-15T19:25:56.873327+09:00"}

team_drive = 000AAAABBBBCCCCDD

root_folder_id = 1zGG11122233344455_kfkfa_AbCdhw0j

server_side_across_configs = true

 

공유하는 쪽에서 보내주는 team_drive 값을 반드시 추가해야 하고, root_folder_id 도 반드시 넣어야 한다.

자신의 구글 드라이브에 들어가서,  공유 문서함에서 공유된 폴더에 바로 들어갔을 때, 웹브라우저의 주소창에  

https://drive.google.com/drive/u/0/folders/1zGG11122233344455_kfkfa_AbCdhw0j   에서

1zGG11122233344455_kfkfa_AbCdhw0j  와 같은 문자열을  root_folder_id 에 추가한다.

 

 

./rclone --config hook.conf ls mygoogledrive:/dir/

명령으로 디렉토리 내용을 나열할 수 있고,

 

원격 파일의 로컬로 복사는

./rclone --config hook.conf -v --transfers 10 copy mygoogledrive:/dir/bigfile.img /localdir/

와 같은 명령으로, source 쪽은 디렉토리나 파일을 지정할 수 있고,  destination 쪽은 디렉토리만 지정하면 된다. 

 

hook.conf 파일을 ~/.config/rclone/rclone.conf로 복사하면, --config hook.conf  옵션이 없는 상태로도 간단히 위의 명령어들을 사용할 수 있다.

Posted by 훅크선장
, |

아래와 같이 Pycharm 개발환경에서는 로컬 컴퓨터의 anaconda 같은 가상환경이나 원격 ssh 로그인을 하는 interpreter 환경은 바로 지원하지만, 원격 ssh 상태에서 anaconda 환경을 사용할 수 있는 방법은 없는 것으로 알려져 있다.

 

https://youtrack.jetbrains.com/issue/PY-35978

 

No way to activate conda environment for remote interpreter : PY-35978

What steps will reproduce the problem? 1. Create a new Remote (SSH) Interpreter 2. Point it to the python executable of an existing conda env. on a remote server (ᐸenv_pathᐳ/bin/python) 3. Try to run some code using this interpreter. What is the expect

youtrack.jetbrains.com

 

그러나, 위와 같이 별도 스크립트 파일을 통해서, 원격 anaconda 환경을 인터프리터로 사용할 수 있다.

 

 

원격 ssh 로그인 환경에서 아래와 같은 쉘 스크립트 파일을 하나 생성한다. 파일명을 python 이라고 해도 되고, 다른 이름을 원하는 대로 생성하면 된다. 여기서 아래 스크립트 파일명은 python_env 이다.

 

#!/usr/bin/env bash

source /home/jetbrains/miniconda3/etc/profile.d/conda.sh
conda activate py_35978
python "$@"

 

위의 경로명에서 /home/jetbrains/miniconda3 부분은 자신의 ssh 로그인 환경에 맞게 수정한다.

 py_35978 이라는 가상환경 명도 자신의 환경에 맞게 수정한다.

※ 참고로 나는 추가적으로 python "$@" 줄을 python3 "$@"로 수정했다.


ssh 로그인 상태에서 chmod +x python_env  명령으로, 실행파일로 생성한다.

./python_env  명령을 실행하였을 때, 파이썬 쉘 환경이 되어야만 정상적인 것이다.

 

PyCharm에서 새로운 프로젝트를 생성하고, SSH 인터프리터를 원격  ssh 서버로 지정한 다음, Interpreter 를 기존의  /usr/bin/python 이 아니라,  /home/jetbrains/python_env  와 같이, 앞에 생성한 쉘 스크립트의 정확한 경로명과 파일명을 적어준다. 

 

새로운 프로젝트에서 Terminal 창을 열고서, 다음과 같은 파이썬 코드를 입력한다.
import os
print(os.environ.get('CONDA_PREFIX'))

 

아마 결과가  다음과 같이 출력되면, 정상적인 설정이 된 것이다.
/home/jetbrains/miniconda3/envs/py_35978

 

Posted by 훅크선장
, |

gnuradio의 예제, 2020년도에 직접 실험한 것들

HackRF one, RTL-SDR, BladeRF  등

 

 

 

 

RTL-SDR_FM_radio_receiver_with_freq_slider.grc
0.02MB
RTL-SDR_FM_radio_receiver_with_freq_selection.grc
0.02MB
get_sig.grc
0.01MB
send_sig.grc
0.01MB
FM_Receiver.grc
0.01MB
fm_example_by_HooK.grc
0.04MB

윈도우즈에서 만든 간단한 예제 FM_Receiver.grc 에서는  음성 신호 마지막이 24KHz 인데, 이 설정이 리눅스 (칼리리눅스) 에서 Alsa 오디오 드라이버에서는 지원되지 않는 음성주파수 라고 나온다. 2배로 늘려서, 48KHz 로 하면, 정상적으로 출력된다. 

48KHz로 설정하였으면, 바로 앞단계의 Re Sampling도 48로 맞춰줘야 한다.

 

Posted by 훅크선장
, |

최근에 아마추어 햄을 시작하면서, 아마추어 무선기사 4급 자격을 취득하고, 장비를 구입했습니다.

저렴하면서도 성능이 적당한 Yaesu FT-65E 제품입니다. (일본제이지만, 선택의 여지가 별로 없어서...)

https://www.radioworld.co.uk/ft-65e-vhfuhf-2m70cm-dual-band-fm-handheld

 

Yaesu FT-65E VHF-UHF, 2m-70cm, Dual Band FM Handheld power settings 5W, 2.5W, and 0.5W.

The Yaesu FT-65E is very compact and light, yet ruggedly constructed. Three selectable output power settings – 5W, 2.5W, and 0.5W. The big front speaker provides a full 1 Watt of powerful very crisp and clear audio in keeping with YAESU's uncompromising

www.radioworld.co.uk

중국 제조이지만, 중국 브랜드 Baofeng 같은 것보다는 훨씬 낫다는 의견이 많아서 구입했습니다.

 

문제는 송수신기에 주파수를 비롯한 여러 설정을 입력하는데, 손으로 일일히 입력하기에는 시간도 많이 걸리고, 그 많은 주파수와 설정을 종이에 기록해놓을 수도 없는데...

전파 송수신기(무전기)도 장비이다 보니, 컴퓨터를 연결해서 설정을 입력할 수 있는 케이블이 따로 있었습니다.

어떤 브랜드는 무전기 살때, 케이블도 같이 넣어주기도 한다는데, 우리의 일본제는 그런거 없이 아예 따로 팔더군요~! 역시나.

https://www.amazon.com/Yaesu-SCU-35-Programming-FT-25R-Handheld/dp/B06W9G8DDD

 

Amazon.com

Enter the characters you see below Sorry, we just need to make sure you're not a robot. For best results, please make sure your browser is accepting cookies.

www.amazon.com

가격이 30달러를 상회하고, 해외 직구의 배송료까지 하면, 몇 만원이 훌쩍 넘는 가격으로, 무전기 가격의 30%에 육박할 수도 있었습니다.

이 케이블은 FT-25, FT-65, FT-4X 등에 공통적으로 사용할 수 있습니다.

그래서, 이 케이블을 DIY한 양덕이 있는지 검색했습니다. 역시 있었습니다. 아래와 같이, 케이블을 직접 분석해서 만든 외국인이 있었습니다.

https://www.youtube.com/watch?v=Xqw2q3maDyU

https://www.youtube.com/watch?v=1JLbUCwtwak

아래와 같은 회로도를 확인하여, 시도해보기로 하였습니다.

회로도는 워낙 간단해서, 케이블 제작이 별로 어렵지 않은데, 문제는 적절한 부품을 구하는 데에 시간이 걸리는 것이었죠.

1N4001 다이오드는 매우 범용 다이오드라서, 구하기 어렵지 않지만, USB to TTL 보드는 3.3v 5v 겸용을 구하는 것이 필요하고, 2.5mm 스테레오 잭 플러그도 일반적으로 쓰는 3.5mm 스테레오 잭이 아니라서 별도로 구해야 합니다.

 

일단 보유하고 있는 USB to TTL 보드와 1N4001 다이오드를 브래드보드에 꽂고, 2.5mm 스테레오 잭 플러그는 아주 오래전 3G 휴대폰용 이어폰마이크에서 잘라서 사용해봤습니다.

브래드 보드를 이용한 테스트에서는 CHIRP 프로그램으로 데이터 읽어오기와 데이터 쓰기가 잘 되었습니다.

너무 간단한 구조라서 살짝 놀라기는 했는데, 잘 되서 아주 좋았습니다.

 

그래서, 케이블을 만들어봤습니다.

부품은 USB to TTL 보드에 핀헤더소켓 6구를 연결하는 형태로 했습니다.  USB to TTL 보드는 다른 용도로도 사용해야 하기 때문에, 탈부착식으로 만들었습니다. 핀헤더소켓 6구에 1N4001 다이오드를 구부려 TX,RX에 연결하고(방향에 주의해서), 거기에 휴대폰 마이크이어폰에서 잘라낸  2.5mm 스테레오 잭 케이블을 납땜하였습니다. 마무리는 수축튜브로 했습니다. (납땜전에 미리 수축튜브에 케이블에 걸어줘야 합니다)

생각보다 볼품도 없고, 케이블의 연결 강도도 높지는 않지만, 그래도 아주 잘 동작합니다.

 

Yaesu 홈페이지에서 memory programmer 프로그램을 받아서도, 케이블을 연결하고 테스트해봤습니다.

아주 만족스럽게, 송수신기로부터 데이터 읽기와 쓰기가 가능하였습니다.

이렇게 어쩌면 매우 간단하게, Yaesu SCU-35 케이블을 복제할 수 있게 되었습니다.

 

집에서 직접 납땜으로 케이블을 만들기 위해서는 다음과 같은 부품들이 있으면 됩니다.

1. USB to TTL 보드 (3.3v 지원 필요)

2. 2.5mm 스테레오 잭 플러그

3. 1N4001 다이오드

4. 핀헤더소켓 6구 

5. 약간의 전선 2가닥 (약 20~30cm)

 

1. https://www.devicemart.co.kr/goods/view?no=1362010 

 

FT232BL USB to TTL 시리얼 모듈 [SZH-CH024]

mini-5P USB / FT232BL chip / Power : 5V or 3.3V / Size : 45mm X 24mm

www.devicemart.co.kr

또는 https://www.devicemart.co.kr/goods/view?no=1324910 또는 https://www.devicemart.co.kr/goods/view?no=1321026

 

CH340G USB to TTL 컨버터 모듈 [SZH-EK092]

간단설명 : Dual 3.3V, 5V 출력 / Status LED / 55mm * 16mm

www.devicemart.co.kr

 

CP2102 USB to TTL 컨버터 모듈 [SZH-CVBE-012]

CP2102 USB to RS232 Converter 칩셋 기반 / USB to TTL 프로젝트에 알맞도록 설계 / Status LED / 3.3V, 5V 모두 호환 가능 / 42mm * 17mm / 케이블 포함

www.devicemart.co.kr

2. https://www.devicemart.co.kr/goods/view?no=15870

 

PJ-플러그 2.5파이/스테레오

스테레오 커넥터 / 2.5mm / MALE / 몸통 부분 모양 랜덤 발송

www.devicemart.co.kr

3. https://www.devicemart.co.kr/goods/view?no=22

 

1N4001

50V, 1A / 벌크 단위 판매

www.devicemart.co.kr

4. https://www.devicemart.co.kr/goods/view?no=12136 

 

핀헤더소켓 Single 1x6 Straight(2.54mm)

핀헤더 소켓 / 스트레이트 타입 / DIP 타입 / 2.54mm pitch / 1열 / 6pin

www.devicemart.co.kr

5. 전선은 납땜하기 적당한 굵기의 아무거나 2가닥만 있으면 됩니다.

이상, 나만을 위한 자작기였습니다.

 

-------------------------------------------------------------------------------------------------------------------

이전에 만든 케이블이 급조한 부품으로 만든 것이라, 너무 안 이뻐서, 위의 부품들을 가지고 이쁘게 다시 만들었습니다.

위에서 사용한 부품과는 다르게, 4번 핀헤더소켓 6구 대신에,

듀퐁 6구 암 커넥터가 있어야 하고, 약간의 열수축튜브을 사용하였습니다.

제작하기전에 새로이 구매하여 도착한 부품들을 먼저 보여드립니다.

먼저 전선과 다이오드를 방향에 맞게 연결해줍니다. (회로도를 잘 보고, 다이오드 방향을 잘 봐서 해야 합니다.)

다이오드가 연결되면, 열수축튜브로 한번 감싸줍니다. (아무래도 좁은 공간에 들어가니깐, 의도치않은 합선이 있을 수 있으므로)

회로도에 맞게, 2.5mm 스테레오 잭의 연결단자에 각각의 선을 납땜해 줍니다. (검정선은 GND, 노란색은 PC측의 TX, 흰색은 PC측의 RX 입니다.)

2.5mm 스테레오 잭을 잘 조립해줍니다.

스테레오 잭의 반대편 선에는 USB to TTL 보드를 연결하기 위한, 듀퐁 2.54mm 암 커넥터를 연결해서 납땜합니다.

전선 세가닥이 서로 흩어지지 않게, 다시 열수축튜브로 묶어준 다음에, 듀퐁 6구 커넥터 하우징을 조립해서 완성합니다.

그리고, 보드와 위치에 맞게 연결해서 완성합니다.

이제 완성해서, 앞절과 같이 FT-65 송수신기와 컴퓨터 USB를 연결하여 프로그래밍을 하면 됩니다.

Posted by 훅크선장
, |

이것은 OpenWRT 유무선 공유기를 가지고, 기존에 존재하는 무선네트워크를 확장해서 유선으로 연결 가능한 원격 네트워크를 만드는 방법이다.

https://openwrt.org/docs/guide-user/network/wifi/relay_configuration  의 번역판이라고 보면 된다.

그림에서 보이는 바와 같이 기존의 유무선 네트워크를 무선 네트워크를 이용하여 확장하는 개념이다.

위 그림에서와 같이, 기존에 이미 192.168.1.1 이라는 유무선 공유기에 유무선 네트워크를 사용하고 있는 상황에서 유선 클라이언트들이 192.168.1.1 에 접근하기 너무 멀다면, 192.168.2.1/192.168.1.30 이라는 유무선공유기를 통해서, 기존 192.168.1.1 네트워크를 확장해서 사용하는 것이다.

 

0. openwrt 라우터 초기화 

root@WClient2:~# firstboot && reboot now
This will erase all settings and remove any installed packages. Are you sure? [N/y]
y
/dev/mtdblock5 is mounted as /overlay, only erasing files
root@WClient2:~# Connection to 192.168.1.1 closed by remote host.
Connection to 192.168.1.1 closed.


1. relayd 설치

root@OpenWrt:~# opkg list |grep relayd
luci-proto-relay - git-19.307.61018-284918b - Support for relayd pseudo bridges
relayd - 2020-04-25-f4d759be-1 - Transparent routing / relay daemon
root@OpenWrt:~# opkg install relayd
Installing relayd (2020-04-25-f4d759be-1) to root...
Downloading https://downloads.openwrt.org/releases/21.02.1/packages/mips_24kc/base/relayd_2020-04-25-f4d759be-1_mips_24kc.ipk
Configuring relayd.
root@OpenWrt:~# opkg install luci-proto-relay
Installing luci-proto-relay (git-19.307.61018-284918b) to root...
Downloading https://downloads.openwrt.org/releases/21.02.1/packages/mips_24kc/luci/luci-proto-relay_git-19.307.61018-284918b_all.ipk
Configuring luci-proto-relay.
root@OpenWrt:~# 

2. LAN 네트워크 IP 주소 변경 (반드시 ssh 콘솔로)

IP 주소만 수정.  WClient 192.168.2.1
과 같이, 기존의 디폴트 192.168.1.1이 아닌 사설네트워크로 일종의 관리용 네트워크 대역을 설정하는 것이다.

root@OpenWrt:~# vi /etc/config/network

...

config interface 'lan'

option proto 'static'

option netmask '255.255.255.0'

option ip6assign '60'

option ipaddr '192.168.2.1'

option device 'br-lan'

...

...

ssh 로 로그인해서, /etc/config/network 파일 내용을 직접 수정하고 reboot.


2-1. LAN 네트워크의 DHCP 비활성화 
웹 브라우저로 192.168.2.1로 로그인한 다음,

Network 페이지의 Interfaces 로 간 다음, LAN 항목의 EDIT로 들어가서,

DHCP Server 설정 탭에 가서, Ignore interface 네모에 체크하여, DHCP 비활성화 시킨다.

3. 무선랜 클라이언트 설정
wireless 페이지로 이동하여, 네트워크에서 Scan을 누르고, 원하는 무선 네트워크에 가입한다.
예제) SCAN 해서, KIM 네트워크를 찾아서, 클릭하고 들어간다. WPA 패스워드를 입력한다.
Name of the new network 는 wwan 이라고 그대로 둔다.
Assign firewall-zone 에서  lan을 지정한다.  

3-1. 무선 디바이스 설정 
wifi의 디바이스 설정으로 오면, 
Operating frequency를 반드시 잘 설정해야만 한다. 우리가 가입하려고 하는 무선네트워크와 동일한 mode 여야 한다.

Channel은 다른 클라이언트들과 겹치지 않게 한다.

4. 리피터 repeater 인터페이스 생성
Interface 페이지로 이동하여, Add New Interface 를 클릭 
Name에 repeater_bridge 를 입력 ※ 원하는 다른 이름을 넣어도 되는데, 직관적인 이름 사용
Protocol에 Relay bridge 를 선택 
※ 만약 Relay bridge가 없다면, 앞 과정에서 relayd 설치하고 나서, reboot를 안했을 수도 있으므로,
relayd를 설치하고 장비 리부팅하고, 다시 들어오면 된다.

4-1. repeater_bridge 인터페이스 설정
Protocol은 Relay bridge로 그대로 두고, Relay between networks 에서 lan과 wwan을 선택
제일 중요한 것이 Local IPv4 address인데, 여기에는 실제 Relay 되는 네트워크 대역의 IP를 써야한다.
예제) 앞에서 관리용 목적으로 LAN 네트워크를 192.168.2.1를 선택했는데, 이것과 관련된 것을 쓰는 것이 아니고,
실제 무선네트워크에 Client로 연결해서 사용되는 네트워크 대역에서 이 장비에 할당할 IP를 써주는 것이다. 
위 그림에서 보는 바와 같이, 기존 유무선공유기 네트워크가 192.168.1.1/24 대역이므로, 192.168.1.30을 써주면 된다.

4-2. repeater_bridge 파이어월 설정
repeater_bridge의 Firewall Settings 로 가서,
Assign firewall-zone에서 lan 을 선택한다.

5. 장비 재부팅 후, 확인사항
무선 네트워크에 잘 가입되어 있는지 확인!!
Firewall - Zone Settings에 가서, Zones 영역에 lan, repeater_bridge, wwan이 같이 묶여서, wan으로 모두 accept 되고 있는 지를 확인!!
장비에 유선으로 연결된 컴퓨터가 무선네트워크 IP를 dhcp로 잘 가져오는 것을 확인!!

 

이것으로 끝~!!

Posted by 훅크선장
, |

1. vagrant 설치 : with Brew on Mac OS X 
user@Mac ~ % /bin/bash -c "$(curl -fsSL  https://raw.githubusercontent.com/Homebrew/install/HEAD/install.sh)"

user@Mac ~ % brew tap hashicorp/tap
user@Mac ~ % brew install vagrant

※ vagrant 설치 : CentOS 7 Linux
sudo yum install -y yum-utils
sudo yum-config-manager --add-repo https://rpm.releases.hashicorp.com/RHEL/hashicorp.repo
sudo yum -y install vagrant

2. ambari-vagrant git clone
user@Mac ~ % git clone https://github.com/u39kun/ambari-vagrant.git

3. /etc/hosts 호스트 추가(설치할 os 버전 부분만)
user@Mac ~ % cat ambari-vagrant/append-to-etc-hosts.txt
※ vagrant의 모든 호스트가 들어있는 파일로, 여기서는 # centos 7.4 부분만 필요하다.

 

user@Mac ~ % sudo vi /etc/hosts
...
# centos 7.4
192.168.74.101 c7401.ambari.apache.org c7401
192.168.74.102 c7402.ambari.apache.org c7402
192.168.74.103 c7403.ambari.apache.org c7403
192.168.74.104 c7404.ambari.apache.org c7404
192.168.74.105 c7405.ambari.apache.org c7405
192.168.74.106 c7406.ambari.apache.org c7406
192.168.74.107 c7407.ambari.apache.org c7407
192.168.74.108 c7408.ambari.apache.org c7408
192.168.74.109 c7409.ambari.apache.org c7409
192.168.74.110 c7410.ambari.apache.org c7410
...


4. vagrant private key 생성
user@Mac ~ % vagrant ~/.vagrant.d/insecure_private_key

5. pre-configured VM 사용하기 
user@Mac ~ % cd ambari-vagrant/centos7.4/
user@Mac ~ % vi Vagrantfile 

(dev-bootstrap.sh이 있는  line 29  주석 해제)
...

c7401.vm.provision :shell, :path => "dev-bootstrap.sh"

...

6. dev-bootstrap.sh 파일 수정 
※ ambari build 를 위한 적절한 버전의 소프트웨어 사용 설정
user@Mac ~ % vi dev-bootstrap.sh

...
wget https://nodejs.org/dist/v8.11.2/node-v8.11.2-linux-x64.tar.gz
tar zxvf node-v8.11.2-linux-x64.tar.gz
mv node-v8.11.2-linux-x64 /usr/share/node
/usr/share/node/bin/npm install -g brunch
...
wget https://archive.apache.org/dist/maven/maven-3/3.5.3/binaries/apache-maven-3.5.3-bin.tar.gz
tar zxvf apache-maven-3.5.3-bin.tar.gz
mv apache-maven-3.5.3 /usr/share/maven
...


7.VM 생성
user@Mac ~ % cd

user@Mac ~ % cd ambari-vagrant/centos7.4/
user@Mac ~ % cp ~/.vagrant.d/insecure_private_key .
user@Mac ~ % vagrant up c7401

※ vagrant VM을 전체 삭제하려면,
user@Mac ~ % vagrant destroy -f

6.VM 접속
user@Mac ~ % vagrant ssh c7401

7. root 유저로 변환
[vagrant@c7401 ~]$ sudo su -

8. Ambari 2.7.5.0 버전 다운로드 및 mvn 버전 세팅
# wget https://www-eu.apache.org/dist/ambari/ambari-2.7.5/apache-ambari-2.7.5-src.tar.gz
# tar xfvz apache-ambari-2.7.5-src.tar.gz
# cd apache-ambari-2.7.5-src
# mvn versions:set -DnewVersion=2.7.5.0.0
# pushd ambari-metrics
# mvn versions:set -DnewVersion=2.7.5.0.0
# popd

9. Ambari rpm build

1) 개발 패키지 설치 

# yum install python-devel.x86_64

 

2) ambari-admin 폴더의 pom.xml 수정 

# cd ambari-admin/

# vi pom.xml

...

          <nodeVersion>v8.11.2</nodeVersion>
          <npmVersion>5.6.0</npmVersion>

...

# cd ..

 

3) ambari-metrics 폴더의 pom.xml 수정 (line 42-50)

# cd ambari-metrics/

# vi pom.xml

...

    <hbase.tar>https://archive.apache.org/dist/hbase/2.0.2/hbase-2.0.2-bin.tar.gz</hbase.tar>
    <hbase.folder>hbase-2.0.2</hbase.folder>
    <hadoop.tar>https://archive.apache.org/dist/hadoop/common/hadoop-3.1.4/hadoop-3.1.4.tar.gz</hadoop.tar>
    <hadoop.folder>hadoop-3.1.4</hadoop.folder>
    <hadoop.version>3.1.4</hadoop.version>
    <grafana.folder>grafana-6.7.4</grafana.folder>
    <grafana.tar>https://dl.grafana.com/oss/release/grafana-6.7.4.linux-amd64.tar.gz</grafana.tar>
    <phoenix.tar>https://downloads.apache.org/phoenix/apache-phoenix-5.0.0-HBase-2.0/bin/apache-phoenix-5.0.0-HBase-2.0-bin.tar.gz</phoenix.tar>
    <phoenix.folder>apache-phoenix-5.0.0-HBase-2.0-bin</phoenix.folder>

...

# cd ..

 

4) ambari-metrics/ambari-metrics-timelineservice 폴더의 pom.xml 수정 (line 929)

# cd ambari-metrics/ambari-metrics-timelineservice/

# vi pom.xml

...

 file="${project.build.directory}/embedded/${phoenix.folder}/phoenix-5.0.0-HBase-2.0-server.jar

...

# cd ..


5) Build

# mvn -B clean install rpm:rpm -DnewVersion=2.7.5.0.0 -DbuildNumber=5895e4ed6b30a2da8a90fee2403b6cab91d19972 -DskipTests -Dpython.ver="python >= 2.6" -Drat.numUnapprovedLicenses=600

 

[INFO] Scanning for projects...
...

...

...

[INFO] Executing(%clean): /bin/sh -e /var/tmp/rpm-tmp.W4O5wJ
[INFO] + umask 022
[INFO] + cd /root/apache-ambari-2.7.5-src/ambari-infra/ambari-infra-manager-it/target/rpm/ambari-infra-manager-it/BUILD
[INFO] + /usr/bin/rm -rf /root/apache-ambari-2.7.5-src/ambari-infra/ambari-infra-manager-it/target/rpm/ambari-infra-manager-it/buildroot
[INFO] + exit 0
[INFO] ------------------------------------------------------------------------
[INFO] Reactor Summary:
[INFO] 
[INFO] Ambari Main 2.7.5.0.0 .............................. SUCCESS [  4.795 s]
[INFO] Apache Ambari Project POM .......................... SUCCESS [  0.172 s]
[INFO] Ambari Web ......................................... SUCCESS [ 54.736 s]
[INFO] Ambari Views ....................................... SUCCESS [  2.374 s]
[INFO] Ambari Admin View .................................. SUCCESS [  6.410 s]
[INFO] ambari-utility 1.0.0.0-SNAPSHOT .................... SUCCESS [ 33.500 s]
[INFO] ambari-metrics ..................................... SUCCESS [  1.068 s]
[INFO] Ambari Metrics Common .............................. SUCCESS [  9.894 s]
[INFO] Ambari Metrics Hadoop Sink ......................... SUCCESS [ 10.069 s]
[INFO] Ambari Metrics Flume Sink .......................... SUCCESS [  2.123 s]
[INFO] Ambari Metrics Kafka Sink .......................... SUCCESS [  2.115 s]
[INFO] Ambari Metrics Storm Sink .......................... SUCCESS [  3.453 s]
[INFO] Ambari Metrics Storm Sink (Legacy) ................. SUCCESS [  3.210 s]
[INFO] Ambari Metrics Collector ........................... SUCCESS [07:29 min]
[INFO] Ambari Metrics Monitor ............................. SUCCESS [  2.178 s]
[INFO] Ambari Metrics Grafana ............................. SUCCESS [  9.604 s]
[INFO] Ambari Metrics Host Aggregator ..................... SUCCESS [ 22.365 s]
[INFO] Ambari Metrics Assembly ............................ SUCCESS [03:35 min]
[INFO] Ambari Service Advisor 1.0.0.0-SNAPSHOT ............ SUCCESS [ 27.628 s]
[INFO] Ambari Server ...................................... SUCCESS [  01:15 h]
[INFO] Ambari Functional Tests ............................ SUCCESS [  2.111 s]
[INFO] Ambari Agent ....................................... SUCCESS [-58.-229 s]
[INFO] ambari-logsearch ................................... SUCCESS [  1.735 s]
[INFO] Ambari Logsearch Appender .......................... SUCCESS [  4.152 s]
[INFO] Ambari Logsearch Config Api ........................ SUCCESS [  0.403 s]
[INFO] Ambari Logsearch Config JSON ....................... SUCCESS [  0.398 s]
[INFO] Ambari Logsearch Config Solr ....................... SUCCESS [ 12.952 s]
[INFO] Ambari Logsearch Config Zookeeper .................. SUCCESS [  1.690 s]
[INFO] Ambari Logsearch Config Local ...................... SUCCESS [  0.197 s]
[INFO] Ambari Logsearch Log Feeder Plugin Api ............. SUCCESS [  9.075 s]
[INFO] Ambari Logsearch Log Feeder Container Registry ..... SUCCESS [  9.950 s]
[INFO] Ambari Logsearch Log Feeder ........................ SUCCESS [01:01 min]
[INFO] Ambari Logsearch Web ............................... SUCCESS [01:14 min]
[INFO] Ambari Logsearch Server ............................ SUCCESS [  02:27 h]
[INFO] Ambari Logsearch Assembly .......................... SUCCESS [  4.325 s]
[INFO] Ambari Logsearch Integration Test .................. SUCCESS [02:39 min]
[INFO] ambari-infra ....................................... SUCCESS [  1.036 s]
[INFO] Ambari Infra Solr Client ........................... SUCCESS [ 12.429 s]
[INFO] Ambari Infra Solr Plugin ........................... SUCCESS [ 29.353 s]
[INFO] Ambari Infra Manager ............................... SUCCESS [01:34 min]
[INFO] Ambari Infra Assembly .............................. SUCCESS [  1.477 s]
[INFO] Ambari Infra Manager Integration Tests 2.7.5.0.0 ... SUCCESS [ 51.914 s]
[INFO] ------------------------------------------------------------------------
[INFO] BUILD SUCCESS
[INFO] ------------------------------------------------------------------------
[INFO] Total time: 03:53 h
[INFO] Finished at: 2021-06-30T04:58:54Z
[INFO] ------------------------------------------------------------------------

Posted by 훅크선장
, |