brew를 사용할 때 go의 여러 버전을 설치해서 바꿔가며 사용할 수 있다.
특정 버전을 설치할 때는 다음과 같이 한다.
brew install go@1.14
특정 버전을 선택해서 사용할 때는 다음과 같이 한다.
brew link --force go@1.14
brew link --overwrite go@1.14
brew를 사용할 때 go의 여러 버전을 설치해서 바꿔가며 사용할 수 있다.
특정 버전을 설치할 때는 다음과 같이 한다.
brew install go@1.14
특정 버전을 선택해서 사용할 때는 다음과 같이 한다.
brew link --force go@1.14
brew link --overwrite go@1.14
git bisect start <bad> <good>
후 git bisect run <command>
로 찾는다.
맥에서 “too many open files” 에러 나면서 안되는 경우가 있다. Linux에 비해 limits이 너무 적기 때문이다.
Big sur 기준
sudo vi /Library/LaunchDaemons/limit.maxfiles.plist
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
<plist version="1.0">
<dict>
<key>Label</key>
<string>limit.maxfiles</string>
<key>ProgramArguments</key>
<array>
<string>launchctl</string>
<string>limit</string>
<string>maxfiles</string>
<string>524288</string>
<string>524288</string>
</array>
<key>RunAtLoad</key>
<true/>
<key>ServiceIPC</key>
<false/>
</dict>
</plist>
2. sudo launchctl load -w /Library/LaunchDaemons/limit.maxfiles.plist
3. sudo vi /Library/LaunchDaemons/limit.maxproc.plist
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE plist PUBLIC "-//Apple/DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
<plist version="1.0">
<dict>
<key>Label</key>
<string>limit.maxproc</string>
<key>ProgramArguments</key>
<array>
<string>launchctl</string>
<string>limit</string>
<string>maxproc</string>
<string>2048</string>
<string>2048</string>
</array>
<key>RunAtLoad</key>
<true />
<key>ServiceIPC</key>
<false />
</dict>
</plist>
4. sudo launchctl load -w /Library/LaunchDaemons/limit.maxproc.plist
5. sudo sysctl -w kern.maxfiles=5242880
6. sudo sysctl -w kern.maxfilesperproc=524288
7. Reboot
다음과 같이 하면 diff 시 whitespace 에러가 강조되어 보인다.
git config --global diff.wsErrorHighlight all
gsed 없는 mac같은 환경에서 파일 내의 trailing space 지우기
find . -name "*.yml" -exec sed -i '' -E 's/[ '$'\t'']+$//' {} \;
구글에서 개발한 structured data를 serialize하는데 사용하는 data format. 줄여서 protobuf로 부른다.
go의 github protobuf 는 “google.golang.org/protobuf/proto” 패키지를 사용하도록 deprecated (https://pkg.go.dev/github.com/golang/protobuf/proto) 되었다.
구글 문서인 proto3의 language guide는 아래.
https://developers.google.com/protocol-buffers/docs/proto3
API reference는 아래에 있다.
https://developers.google.com/protocol-buffers/docs/reference/overview
Go API reference는 아래다.
$ git config --global url.git@github.com:.insteadOf https://dasomoli@github.com/
$ go get github.com/dasomoli/private-repo
참고: https://stackoverflow.com/questions/27500861/whats-the-proper-way-to-go-get-a-private-repository
‘&'(anchor) 와 ‘*’ 의 의미는 https://stackoverflow.com/questions/46641224/what-is-and-in-yaml-mean 를 참고.
여기 잘 정리되어 있다.
https://learnxinyminutes.com/docs/yaml/
이에 대응하는 한글 문서는 https://learnxinyminutes.com/docs/ko-kr/yaml-kr/ 이다.
Pull request가 필요할 거 같다….
트랜잭션 T는 다음 data를 포함한다.
T = { nonce, gasPrice, gasLimit, to, value, data, v, r, s }
function selector
와 그 이후의 function argument
를 serialize한 data이다.function selector = (keccak-256(function prototype))[0:4]
서명 시 사용되는 트랜잭션 T는 9개 필드로 다음과 같다. 이 중 맨 끝의 3개 { chainID, 0, 0 }은 EIP-155에 의해 추가된다. EIP-155는 Simple Replay Attack Protection으로 chainID를 포함하여 다른 네트워크 체인에서 해당 트랜잭션이 replay될 수 없도록 한다.
T = { nonce, gasPrice, gasLimit, to, value, data, chainID, 0, 0 }
Sig는 서명으로 서명 알고리즘, F sig() 로 (r, s) 두 값이 output으로 만들어진다. Transaction T와 private key k를 사용한다. RLP는 Recursive Length Prefix (RLP) encoding scheme 을 말한다.
Sig = F sig(keccak256(RLP(T)), k) = (r, s)
서명 시에는 임시 private key q, 그리고 q로부터 생성되는 임시 public key Q 를 사용한다.
q = rand() % 2**256
Q = q * K = (x, y)
여기서 r = Q의 x 좌표이다. s는 다음으로 계산된다.
s ≡ q**-1 (Keccak-256(RLP(T)) + r * k) mod p
r, s 그리고 sender의 public key K를 사용해서 Q를 계산한다. Q의 x 좌표와 r이 같으면 서명이 유효하다.
w = s**-1 mod p
u1 = Keccak-256(RLP(T)) * w mod p
u2 = r * w mod p
Q ≡ u1 * G + u2 * K (mod p)
참고: https://github.com/ethereumbook/ethereumbook/blob/develop/06transactions.asciidoc
타원 곡선 함수, Elliptic curve cryptography 에서 다음 p를 사용
p = 2**256 - 2**32 - 2**9 - 2**8 - 2**7 - 2**6 - 2**4 - 1
y ** 2 mod p = (x ** 3 + 7) mod p
Private key -> Public key -> Address 로 얻는다.
k가 private key.
k = rand() % (2 ** 256), 따라서 256 bits, 64 bytes.
K가 public key로 (x, y) 좌표. G는 미리 정의된 값.
K = k * G = (x, y)
Public key, K를 표현할 때는 Standards for Efficient Cryptography (SEC1) 의 Serialized EC public key prefixes 의 prefix를 사용해서 나타낸다. 이더리움은 uncompressed point만을 지원하므로 0x04 prefix로 사용한다. 따라서 0x04 뒤에 x와 y를 concatenate한다.
0x04 | x | y
keccak-256 Hash function을 사용. Public key (x, y)를 concatenate한 값(0x04가 붙지 않았다!)을 keccak-256 로 hash 값을 얻은 후 마지막 20 바이트 값을 사용한다.
(keccak-256(x | y))[-20:]