• Как на windows 10 убрать язык из переключения клавишами?

    Ziptar
    @Ziptar
    Дилетант широкого профиля
    Переключение между тремя языками по альт+шифт по-умолчанию:
    spoiler
    63887545321e1925813236.jpeg


    Переключение между ДВУМЯ языками - русским(украинским) и английским по альт+шифт по умолчанию, но между русским и украинским по ктрл+шифт по-умолчанию
    spoiler
    638875b68966a095365725.jpeg
    Ответ написан
    2 комментария
  • Как правильно использовать команды установки служб для Powershell?

    @BeatHazard
    Приветствую.
    Я устанавливаю Zabbix через Powershell таким скриптом:
    Copy-Item -Path "$PSScriptRoot\ZabbixAgent" -Recurse -Destination 'C:\Program Files' -Force
    Start-Process -FilePath "C:\Program Files\ZabbixAgent\bin\zabbix_agentd.exe" -ArgumentList "--config ""C:\Program Files\ZabbixAgent\conf\zabbix_agentd.conf"" --install" -Wait
    Start-Sleep 10
    Start-Service "Zabbix Agent"
    Ответ написан
    1 комментарий
  • В каком направление двигаться начинающему системному администратору?

    Viji
    @Viji
    Associate DevOps Engineer
    В конце концов можно заняться сертифицированием, получите CISCO CCNA или Microsoft сертификаты, автоматизируйте ваши типичные задачи с помощью PowerShel - заодно его выучите, поставьте на один комп Линукс.. дополните его аутентификацией в AD, поизучайте сам Линукс.

    У вас есть свободное время и пространство для развития - кайфуйте с этого!
    Ответ написан
    Комментировать
  • В каком направление двигаться начинающему системному администратору?

    @TheBigBear
    СтарОдмины мы
    Для начала определитесь - стагнация или потеря интереса к профессии
    Даже в рамках одной конторы можно интересно и с пользой для дела получать знания
    Вот навскидку:
    Поиграйтесь с VLAN, разделение сети на сегменты, поднятием MESH
    Поставьте и настройте Zabbix, натравите на мониторинг сети
    Подберите на свой вкус программу инвентаризации и учета (например, GLPI)
    Найдите удалённую подработку
    Самое главное - это чтобы было интересно
    Ответ написан
    Комментировать
  • Какой файловый сервер для Windows Server 2019 с доступом через веб интерфейс?

    @Drno
    Nextcloud
    ставить на Linux
    Ответ написан
    Комментировать
  • Апгрейд HP 250 G5. Можно ли засунуть 2 накопителя?

    anthtml
    @anthtml
    Системный администратор программист радиолюбитель
    1. Разобрать
    2.1. Если есть переходная планка со шлейфа на mini-sata, то Вам люто повезло и можно переходить к п.3
    2.2. Если планки нет, но есть разъем JODD - то ползете на авито/ебэй/разборки/мастерские в поисках планки со шлейфои и после переходите к п.3.
    2.3. Если разъем JODD не распаян - значит второй порт на плате не вывели и тут уже спасет только USB-HDD.
    3. Купить HDD-CADDY и вставить диск
    Ответ написан
    3 комментария
  • Движение данных по локальной сети?

    Кажется, вы сильно непонимание как работают сети. Стоит прочитать цикл статей https://linkmeup.ru/blog/1188/
    Ответ написан
    Комментировать
  • Есть ли риск спалить системник при использовании блока питания с 450 ватт?

    nava2002
    @nava2002
    Инженер
    Выше все абсолютно верно написано.
    Хочу обратить внимание НА:
    Обычный (не 80+ "Голд ....") БП имеет реальную выходную мощность примерно 50% от заявленной на корпусе.
    Хороший запас по мощьности считается 1,5 раза.

    Возвращаясь к данной ситуации из БП 450 получим реальных 225Вт.
    Система с расходом 160 (видеокарта) + 90 (процесоор, материнка, HDD) получаем 250Вт.
    Тоесть даже 500 Вт. это как бы на перделе. Я бы взял 600Вт а лучше 700Вт. обычный или 500 Вт. "80+" (Бронза, голд...)
    В общем если работает можно и так оставить, но стабильность системы будет под большим вопросом.
    Ответ написан
    Комментировать
  • Есть ли риск спалить системник при использовании блока питания с 450 ватт?

    vabka
    @vabka
    Токсичный шарпист
    При повышении нагрузки либо будет аварийное выключение из-за просадки напряжения, либо будет перегрев БП.
    При перегреве БП будет либо аварийное выключение БП, вместе со всем компьютером, либо произойдёт повреждение компонентов БП.
    При этом может произойти возгорание БП, а потом и всего компьютера, если разгорится хорошо.
    Также может произойти какой-нибудь интересный электрический эффект, из-за чего может произойти КЗ или ещё что неприятное, из-за чего даже без возгорания твои дорогие комплектующие, в лучшем случае, придётся ремонтировать.

    В целом, даже если 450вт фактически хватает - он будет на предельных значениях работь, а тут и КПД ниже, и нагрев больше.
    + со временем (с годами) общая мощность БП может падать.

    Так что лучше в ближайшее время купить более мощный БП.
    Ответ написан
    Комментировать
  • Не работает интернет от свитча?

    martin74ua
    @martin74ua
    Linux administrator
    Обратитесь к системному администратору вашей компании
    Ответ написан
    2 комментария
  • Можно ли питать компьютерные комплектующие от разных источников питания?

    Adler_lug
    @Adler_lug
    Как правильно организовать такую схему?

    Купить один нормальный блок питания и не страдать херней...
    Ответ написан
    3 комментария
  • Восстановление данных с накопителя видеорегистратора?

    Zettabyte
    @Zettabyte
    Проф. восстановление данных ▪ Вопрос? См. профиль
    По глупой случайности инициализировал диск в Windows.
    Вполне типовая ситуация, с которой к нам регулярно приходят пользователи DVR.

    Можно ли с этим *.bin файлом секторов восстановить данные у профильных людей?
    Да, образ оригинального жёсткого диска, который был инициализирован, подойдёт для восстановления данных с видеорегистратора.

    И является ли полный бэкап данных секторов полной копией диска?
    Никогда не пользовался Bootice. Обязательно учтите, что вам нужен полный образ диска (посекторная копия, клон), сделанный в режиме "байт-в-байт". Без ухищрений, пропусков, сжатия, проприетарных форматов, и т.п. Т.е. Acronis и подобные инструменты не подойдут.
    Используйте CloneZilla или 16-тиричный редактор. Если потребуется, у нас есть бесплатный hex-редактор, не требующий установки.

    Начал экспериментировать на тестовом диске (объем меньший) и смог вернуть диск до исходного состояния ...
    К сожалению, вы очень вряд ли сможете самостоятельно привести диск к виду, когда его можно будет вставить обратно в регистратор и всё заработает как раньше, за исключением перетёртого куска.

    Производители CCTV-систем видеонаблюдения не ограничены никакими стандартами, они используют проприетарные способы хранения данных. Чаще всего это поток каши из кадров с разных камер, сопровождаемых метаданными различного формата. Нередко где-то рядом лежит "журнал" или "календарь".

    Если вы решите что-то делать сами, то проще будет перевести записи в отдельные видеофайлы для просмотра на компьютере. Но и такая задача у новичка потребует от нескольких месяцев до полугода плотной и регулярной работы над ней. Ну и понятно, нужно умение программировать.

    Есть рисковая идея сделать бэкап секторов, где присутствуют записи, отформатировать диск видеорегистратором, и вернуть забэкапленные секторы на диск.
    План не совсем понятен, но в любом случае обязательно имейте образ исходного диска, в состоянии когда вы его вынули из ДВР. Различные операции записи только уничтожают оригинальные видео.

    Диск требуется отдать в другие руки, но неизвестно что станет с диском в дальнейшем, а записи важные.
    Если содержимое критичное, то лучший вариант - взять полную копию и обратиться с ней к специалистам.
    Если вы в Москве, будем рады помочь с восстановлением видео, если нет, то выбирайте компанию поблизости, используя вот эту краткую памятку, она универсальная: Восстановление-данных.рф
    Ответ написан
    3 комментария
  • Доступное обучение по работе с сетевым оборудованием?

    CityCat4
    @CityCat4
    Внимание! Изменился адрес почты!
    Подбор серверов и коммутаторов без знания того, как эти сервера и коммутаторы работают и что они делают и зачем они это делают - это примерно как подбор автомобиля человеком, всю жизнь ездившим на лошади...
    Ответ написан
    1 комментарий
  • Нормально к одной ip камере подключать 2 регика?

    mixatronik
    @mixatronik
    mixatronik.ru
    На самом деле, проблемы всё-таки могут быть. Протокол ONVIF двунаправленный и регистратор может заказывать параметры потока. Регистратора два и может возникнуть ситуация, когда они запросят поток с разными параметрами. Дальше всё зависит от того, насколько софт камеры и регов умеет обрабатывать такие ситуации. Работать то будет, но не очень стабильно. Камеры могут зависать, поток может прерываться. По ONVIF можно подключить к одному регу, а к другому по RTSP или к обоим по RTSP, а параметры потоков настроить на самой камере. Последний вариант самый трудозатратный, зато самый надёжный.
    Ответ написан
    Комментировать
  • В чем заключаются архитектурные ошибки моего кода?

    trapwalker
    @trapwalker Куратор тега Python
    Программист, энтузиаст
    class Calculation():
    
      def __init__(self, calculation):
        #init
        self.calculation = calculation

    Вы сделали класс `Вычисления`, чтобы проводить вычисления, пока проводятся вычисления вычислений над вычислениями, которые вычисляются как аргумент вычислений для вычисления состояния вычислений.

    Вы бы хотя бы в предметную область нас тут погрузили хоть немножечку. Не понятно же ничерта. Обычно класс и инстанс можно называть одинаково, за исключением первой буквы, но вы тут в аргументы что-то передаёте и то нифига не понятно. Делайте докстринги.

    Используйте тайпхинтинг, это позволяет не только статичесий анализ кода делать и избегать лишних ошибок, но, к тому же, это мощный инструмент документирования кода, неотрывно связанный с самим кодом. Это значит, что документация не отстанет от кода, а, напротив, будет за счет формализма и машиночитаемости помогать IDE помогать нам писать код. К тому же ряд вопросов отпадёт у тех, кто пытается читать код. Не нужно гадать на кофейной гуще что есть что.

    Нужно помнить, что исходный код пишется не для компьютеров, а для людей. Должно ыть удобно код писать, но любой код пишут только один раз, а вот читают его каждй раз, когда нужно разобраться что пошло не так, каждый раз, когда нужно расширить функциональность, исправить ошибки, изменить логику... Читабельность для кода гораздо важнее писабельности.

    У вас в коде полно "магических" констант. Именуйте их и выносите в начало модуля или, хотя бы, указывайте в инлайн-комментах единицы измерения для ясности. Не пренебрегайте свойствами, их можно документировать .

    Вы тут много работаете с календарными периодами. перебираете их с шагом... Это хорошее место для выделения функциональности в отдельную библиотеку, в отдельный тип данных. Возможно писать свой велосипед даже не придётся, ведь найдётся много готовых качественных протестированных библиотека для этих целей. Их будет легко и понятно инициализировать, у них будет простой, понятный и универсальный АПИ, они будут однотипно использованы в разных мемтах проекта, не придётся смешивать в одном контесте кучу переменных для обеспечения двух имплементаций одной и той же функциональности.
    Количество кода резко убавится, универсальный код будет вынесен в отдельный модуль и будет отдельно и полноценно протестирован, а в бизнес логике вы будете коротко и лаконично работать с абстракцией - понятной и простой.

    Вот тут у вас, очевидно, можно написать проще и без лишних повторений, провоцирующих ошибки:
    if i % self.inflation_indexation_period==0 and i != 0:
            if i not in range(0, self.inflation_indexation_period):
              init_indexation_inflation *= self.sales_init.inflation_indexation
            else:
              init_indexation_inflation = 1
            inflation_indexations.append(round(init_indexation_inflation, 5))
          else:
            inflation_indexations.append(round(init_indexation_inflation, 5))

    Лучше так:
    if i % self.inflation_indexation_period==0 and i != 0:
            if i in range(self.inflation_indexation_period):
              init_indexation_inflation = 1
            else:
              init_indexation_inflation *= self.sales_init.inflation_indexation
    
          inflation_indexations.append(round(init_indexation_inflation, 5))

    Функция get_inflation_indexations у вас имеет опасный побочный эффект. Она имеет префикс get_ но модифицирует контекст объекта. Это кэширование? Чем обусловлено такое поведение? Если такое делается "на всякий случай". то это плохая практика неявного внедрения побочного эффекта. Если нарочно, то такое надо документировать и корректно называть и описывать метод в докстринге.

    Опять же, get_inflation_indexations и get_value_indexations очень похожи по коду. Это повод вынести такую логику в отельную функцию, она будет проще и её будет проще тестировать!
    А у вас эти функции отличаются именами атрибутов внутри и магическими константами, которые в коде делать не хорошо, тем более без пояснений, тем более в кусках такого похожего кода.

    Перестаньте использовать i в качестве переменной для итерирования нетривиальных сущностей, отличных от протсого счетчика. i - это индекс. Используйте человеко-понятное название переменной для этого!

    Используйте декоратор итераторов enumerate. Это сделает код более прозрачным и читабельным, чем код с параллельными счетчиками. Увидев enumerate читатель кода сразу поймёт, что это простой счетчик итерируемых сущностей, что не нужно ожидать скачков этого счетчика и каких-то сложных корреляций.

    А вот здесь вообще всё плохо:
    count = 0
        revenue_list = []
        for i in total_price:
          revenue = i*total_value[count]
          revenue_list.append(revenue)
          count+=1

    count - это "количество", а вы его используете как "индекс" и никак иначе!
    i - это индекс, а вы туда суёте фактически цену!
    У вас total_price и total_value параллельные одноразмерные списки, их нужно состегнуть с помощью zip и пронумеровать с помощью enumerate (если надо, а здесь не надо!).
    Весь этот кусок понятнее, проще, короче и более питоничнее записать в такой форме:
    revenue_list = [price * value for price, value in zip(total_prices, total_values)]


    Итого вся вот эта громоздкая плохо читабельная функция:
    def get_revenue(self):
        '''Получить итоговую выручку'''
        total_price = []
        for i in self.get_inflation_indexations():
          price = self.sales_init.price*i
          total_price.append(price)
    
        total_value = []
        for i in self.get_value_indexations():
          value = self.sales_init.sales_volume*i
          total_value.append(value)
    
        count = 0
        revenue_list = []
        for i in total_price:
          revenue = i*total_value[count]
          revenue_list.append(revenue)
          count+=1
    
        return revenue_list

    Легко и читабельно для питониста заменяется на вот такую:
    def get_revenue(self):
        '''Получить итоговую выручку'''
        indexations = self.get_inflation_indexations()
    
        init_price = self.sales_init.price
        total_prices = [init_price * x for x in indexations]
    
        init_volume = self.sales_init.volume
        total_values = [init_volume * x for x in indexations]
    
        return [price * value for price, value in zip(total_prices, total_values)]


    И везде не стоит использовать параллельные счетчики, используйте итераторы, распаковку, зипы, енумервторы и функциональный стиль, ведь он сокращает код и делает его проще.

    Что это за ерунда:
    def get_interest_expenses(self):
        '''процентные расходы'''
        interest_expenses_list = []
        return interest_expenses_list


    Зачем много раз считать одно и то же целиком, чтобы взять только очередной кусочек из всего посчитанного?!
    Это вообще бред. Учитесь основам алгоритмизации и не надо программировать на питоне как не на питоне.

    Вот такое вообще жесть: self.get_revenue()[count]
    Отчего не сохранить в промежуточную переменную?!

    В общем, всё плохо.
    Если у вас есть функция, вычисляющая какой-то список, то зачем её вычислять каждый раз, когда вам нужен только один очередной элеиент этого списка, а вы перебираете его целиком?!
    И так много раз везде!
    Тут не архитектура хромает, тут основы алгоритмизации плачут. Тренируйтесь на кошках, сударь, больше решайте алгоритмических задачек. Структурируйте, декомпозируйте.

    Удачи.
    Ответ написан
    3 комментария
  • Мощный ноутбук для работы и игр?

    @LuchS-lynx
    инженер-ПТО
    С ноутбуками ситуация следующая: Более или менее нормальное железо за свои деньги можно найдти у любого производителя ноутбуков, но дьявол кроется в деталях. Начиная с 4000й серии Ryzen и с 8000-й серии Intel ядер в ноутбуках стало от 6штук/12потоков... что вылилось в полуторакратное увеличение потребляемого питания, т.е. ноутбучные ЦП сегодня потребляют в пике столько же сколько дисктопные ЦП в 2012-2015гг. Т.е. 80-120Вт, может и больше если больше ядер и блок питания, а так же настроенные лимиты по питанию позволяют. Тут не все вендоры одинаково полезны. Та же участь постигла и видеокарты начиная с 2000-й серии от NVidia (RTX это не только классная картинка, но и энергопотребление) Конечно производитель балансит потребление блоком питания и настройками в БИОСе, однако еще есть система охлаждения которая отвратительна в игровых ноутбука:
    - Asus TUF, ASUS ROG (что бы не перегревалось железо зажато под СО),
    - Acer (все модели)
    - MSI (за искл. топовых)
    - Dell (за искл. Alienware на десктопных процессорах)
    - HP (см. Asus)
    - Lenovo (Gaming3, Legion 5/5pro/7 на фоне остальных это сбалансированные игровые машинки, на которых охлад вывозит от 80Вт, в зависимости от модели)
    - Clevo (все ноутбуки, кроме X170/X270 требуют допиливания по частотам и питанию, но в отличие от других ноутбуков здесь сравнительно легко можно разлочить БИОС и становится доступным андервольтинг и изменение PL1 и PL2. Если не знаете что это такое или боитесь, то лучше не связываться. В РФ это Gigabyte G5/G7, DreamMachines, Hasee, Machenike, ThundeRobot, XMG, System76, EuroCom, Sager и др.)

    На счет Acer Nitro - Самый аварийный из всех игровых ноутбуков. Как печатная машинка пойдет, как игровая ... через год-полтора активного гейминга и здравствуй артефакты ВК = приплыли.
    Ответ написан
    1 комментарий
  • Что можно или нужно поменять в этой сборке пк?

    CityCat4
    @CityCat4
    Внимание! Изменился адрес почты!
    Несбалансировано.

    1. Проц из как бы бюджетной сборки, а тачка как бэ игровая
    2. Чудовищная видюха при бюджетном проце и не особо большом количестве памяти будет тупо простаивать
    3. Проверяли, что кулер справится с тепловыделением проца?
    4. Памяти мало, надо 32
    5. сторы судя по цене - дишманские. Зачем?
    6. Мощность БП просчитана? Хватит? БП - очень важная часть, но ее обычно забывают.

    Рекомендации:
    - сократить бюджет на видюху впополам и на эти деньги:
    - проц не ниже i7
    - еще столько же, сколько заложено памяти
    - более надежные сторы, особенно ssd
    - БП от нормального производителя
    Ответ написан
    2 комментария
  • Скрипт для удаления файлов до определенного часа в Windows?

    Crovax
    @Crovax
    Да вообще одной строкой делается.
    Пример:
    Get-ChildItem c:\inetpub\logs\LogFiles\ -Recurse -Filter *.log | Where-Object {$_.LastWriteTime -lt [datetime]::Today.AddMonths(-1)} | Remove-Item
    Ответ написан
    3 комментария
  • Какой систему 2.1 выбрать?

    GavriKos
    @GavriKos
    Все перечисленные +- одно и то же. Идите в магаз, слушайте какие нравятся и все.
    Ответ написан
    4 комментария