reload_flag=""
if [[ -n "${DEBUG}" ]]; then
reload_flag="--reload"
fi
if [[ -n "${WORKER_COUNT}" ]]; then
workers=${WORKER_COUNT}
else
workers=2
fi
gunicorn --workers ${workers} \
--bind 0.0.0.0:8000 \
${reload_flag} main.wsgi
Писали такие конструкции чтобы проверить наличие флага и сформировать команду правильно?
На самом деле можно сделать тоже самое проще. Для этого используются операторы условной подстановки, доступные в оболочках семейства POSIX.
:- для установки значений по умолчанию
${WORKER_COUNT:-2}
Если переменная не объявлена, то будет дефолтное значение 2.
:+ подставляет указанный текст, если переменная не пуста
${DEBUG:+--reload}
Если что-то есть в переменной то распечатается текст после символа +, в противном случае - ничего. Удобно для опциональных флагов, как в нашем примере.
Итого наш скрипт может выглядеть так:
gunicorn --workers ${WORKER_COUNT:-2} \
--bind 0.0.0.0:8000 \
${DEBUG:+--reload} main.wsgi
Есть еще два оператора.
:= не только подставить дефолтное значение, но и присвоить его переменной, если она пуста
# никаких переменных еще нет
VAL1=${VAL2:=hello}
# теперь доступны обе
echo $VAL1 $VAL2
# hello hello
:? остановить выполнение с ошибкой, если переменной нет.
echo ${MISS:?is required}
bash: MISS: is required
Код выхода будет 1.
#tricks#linux
Indian Oil Corp увеличит мощности НПЗ на 25%
Пока нефтепереработчики в Западной Европе и в Китае обсуждают закрытие НПЗ и сокращение объемов перерабатываемой нефти, индийские нефтяники сохраняют оптимизм и строят амбициозные планы.
Шрикант Мадхав Вайя, председатель правления Indian Oil Corp (IOC), крупнейшей нефтеперерабатывающей компании страны, заявил о планах увеличить мощности НПЗ компании на 18 млн т (до 88 млн т). IOC ожидает заметного увеличения спроса на нефтепродукты в ближайшие 25 лет и планирует сохранять "сбалансированный портфель инвестиций", вкладываясь не только в развитие возобновляемой энергетики, но и в нефтегазовый сектор. Планы компании основываются на ожиданиях увеличения спроса на нефть в Индии до 8,3 мбд к 2050 г. (+2,9 мбд к уровню 2023 г.).
Флагманским проектом для IOC остается расширение НПЗ Панипат с 15 млн т до 25 млн т. Проект общей стоимостью $4,7 млрд планировалось завершить уже в сентябре 2024 г., но из-за задержки с поставкой оборудования сроки были "сдвинуты вправо". Сейчас IOC ожидает, что все работы будут завершены к концу 2025 г.
#Нефтепереработка#Индия#IOC
Мои поздравления нашим прекрасным хоккеистам! 🏒🏒🏆🏆
Сначала всей стране пришлось в воскресенье вставать в 7 утра, чтобы посмотреть финальный матч, а потом – еще и изрядно понервничать, ведь немцы боролись насмерть.
А вообще, думаю, эту медаль мы можем смело посвятить президенту Международного олимпийского комитета канадцу Томасу Баху. Уверена, ему было «приятно» смотреть церемонию награждения наших хоккеистов, и слушать как они вместе с болельщиками поют гимн России несмотря на запрет МОК. 🇷🇺🇷🇺🇷🇺
#Чемпионы#олимпийскиеигры#олимпиада2018#olympicgames2018#PyeongChang2018#thomasbach#hockey2018#hockey#IOC#МОК
#yara#awesome_list#blueteam#blueteam_tools#cti#detection#detection_engineering#dfir#hacktools#incident_response#ioc#iocs#ir#ransomware#redteam#rmm#security#siem#soc#threat_hunting#threat_intelligence
You can access comprehensive security detection lists and threat hunting resources that help identify malicious activity across your infrastructure. These curated collections include indicators like suspicious file hashes, domain names, IP addresses, and behavioral patterns organized by threat type—from ransomware and phishing to command-and-control servers and vulnerable drivers. By integrating these lists into your security tools like SIEM platforms and endpoint detection systems, you gain immediate visibility into known threats while learning detection methodologies through guides and YARA rules. This accelerates your ability to hunt for compromises, validate security controls, and stay current with emerging attack techniques without building detection logic from scratch.
https://github.com/mthcht/awesome-lists