Thread Pool2
์๊ฐ์ ์ผ๋ก ๋ง์ ์์ฒญ์ด ๋ค์ด์ค๋ ๊ฒฝ์ฐ Thread Pool์ด ์ด๋ป๊ฒ ๋์ํ๋์ง ์์๋ณด์.
Source code
https://github.com/teamsmiley/gitbook-sample/tree/main/ThreadTest
locust
source code
์์ฒญ์ ํด๋ณด์.
1000๊ฐ์ ์์ฒญ์ ๊ณ์ ๋ณด๋ด๋ Threadpool queue๋ ๋ง์ด ๋์ด๋์ง ์๋๋ค.
์๋๋ฉด ์์ฒญ์ ์ฒ๋ฆฌํ ๋ฐ๋ก ๋ค์ ์์ฒญ์ ์ฒ๋ฆฌํ๊ธฐ ๋๋ฌธ์ด๋ค.
์ด์ 10์ด๋ฅผ ๋๊ธฐํด๋ณด์.
์ด๋ถ๋ถ์ ์ฃผ์์ ์ ๊ฑฐํ๊ณ ๋ค์ ์คํ
๋ชจ๋ ์์ฒญ์ด ํ๋ก ๋ค์ด๊ฐ๊ณ Thread๊ฐ ํ๋์ฉ ์์ฑ์ด ๋๋ค. 10์ดํ์ ์์ฒญ ์ฒ๋ฆฌ ์๋ฃ๋ Thread๋ ๋ค์ pool๋ก ๋ค์ด๊ฐ์๋ง์ ์์ ์ ํ๋ฏ๋ก queue๊ฐ ์ด๋์ ๋ ๋์ด๋ํ ์ํ๋ฅผ ์ ์งํ๋ค.
๋ฌธ์ ๋ฐ์
2000๊ฐ๊ฐ ํ์ ๋ค์ด๊ฐ๊ณ ์ด๋น 1-2๊ฐ์ฉ์ด Thread๊ฐ ์์ฑ์ด ๋๊ณ ์๋ค. ์ด๊ฒ์ ๋ฌธ์ ๊ฐ ๋ฐ์ํ ์ ์๋ค.
Thread ์์ฑ๊ฐ์ง๋ง 1000์ด๋ฅผ ๊ธฐ๋ค๋ ค์ผํ ์๋ ์๋ค.
Threadpool ์ค์ ๋ณ๊ฒฝ
์ด์ Threadpool์ min์ค์ ์ ๋ณ๊ฒฝํด๋ณด์.
๋ค์ ์คํํด๋ณด์.
minThreadworker๊ฐ 1000๊ฐ๋ก ์ค์ ๋์๋ค
ํ ์คํธํด๋ณด์.
1000๊ฐ์ ์ฐ๋ ๋๊ฐ ์์ผ๋ ํ์ ๋ค์ด๊ฐ์ง ์๊ณ 1์ด์ ํ๊ฐ์ฉ ์์ฑ์ด ๋์ง ์๊ณ ๋ชจ๋ ์๋น์ค์ ์ฌ์ฉํ ์ ์๋ค.
๊ฒฐ๋ก
๊ฐ์๊ธฐ ์์ฒญ์ด ๋ง์๊ฒฝ์ฐ๋ ๋ชจ๋ํฐ๋ง์ ํด๊ฐ๋ฉด์ queue๊ฐ 60๊ฐ ์ด์(๋ชจ๋ ์์ฑ๊น์ง ๋ชจ๋ 60์ด๊ฐ ๊ฑธ๋ฆผ) ์ด์์ด ๋๋ฉด minThread๋ฅผ ๋๋ฆฌ๋๊ฒ์ด ์ข๋ค.
๋ ์ค์ํ ๊ฒฐ๋ก
์ฌ๊ธฐ์๋ cpu count๋ ๋ณ ๋ฌธ์ ๊ฐ ์๋๋ค.
1๊ฐ์ cpu๋ 1๊ฐ์ minThread๋ฅผ ๊ฐ์ง๊ณ ์๊ณ 12๊ฐ์ cpu๋ 12๊ฐ์ minThread๋ฅผ ๊ฐ์ง๊ณ ์๋ค.
์์ฒญ์ด ๋ง์ผ๋ฉด 1๊ฐ๋ 12๊ฐ๋ ํฐ ์๋ฏธ๋ ์๋ค๊ณ ๋ณด์ฌ์ง๋ค.
๋ชจ๋ํฐ๋ง์ ์ํด๋ณด์.
๋ ๋ ์ค์ํ ๊ฒฐ๋ก
web api์์ ์์ฒญ์ ๋ฐ์ผ๋ฉด ๋ชจ๋ ๊ฑธ async๋ก ์ฒ๋ฆฌํด์ผํ๋ค. ํนํ db query๋ async๋ก ์ฒ๋ฆฌํด์ผํ๋ค. entity framework์์๋ async method๋ฅผ ์ง์ํ๋ฏ๋ก ๋ชจ๋ ๊ทธ๊ฑธ ์ฌ์ฉํ๋ฉด ์ข์๊ฑฐ๊ฐ๋ค.
Last updated