Горячее
Лучшее
Свежее
Подписки
Сообщества
Блоги
Эксперты
Войти
Забыли пароль?
или продолжите с
Создать аккаунт
Я хочу получать рассылки с лучшими постами за неделю
или
Восстановление пароля
Восстановление пароля
Получить код в Telegram
Войти с Яндекс ID Войти через VK ID
Создавая аккаунт, я соглашаюсь с правилами Пикабу и даю согласие на обработку персональных данных.
ПромокодыРаботаКурсыРекламаИгрыПополнение Steam
Пикабу Игры +1000 бесплатных онлайн игр
Добро пожаловать в Кран-ресторан — казуальный симулятор, который превратит вас в настоящего мастера кулинарии! Управляйте краном, ловите нужные ингредиенты и готовьте блюда по рецептам, избегая ошибок, чтобы сохранить рейтинг и получить ценные награды.

Кран-Ресторан

Казуальные, Аркады, Шарики

Играть

Топ прошлой недели

  • AlexKud AlexKud 38 постов
  • SergeyKorsun SergeyKorsun 12 постов
  • SupportHuaport SupportHuaport 5 постов
Посмотреть весь топ

Лучшие посты недели

Рассылка Пикабу: отправляем самые рейтинговые материалы за 7 дней 🔥

Нажимая кнопку «Подписаться на рассылку», я соглашаюсь с Правилами Пикабу и даю согласие на обработку персональных данных.

Спасибо, что подписались!
Пожалуйста, проверьте почту 😊

Помощь Кодекс Пикабу Команда Пикабу Моб. приложение
Правила соцсети О рекомендациях О компании
Промокоды Биг Гик Промокоды Lamoda Промокоды МВидео Промокоды Яндекс Директ Промокоды Отелло Промокоды Aroma Butik Промокоды Яндекс Путешествия Постила Футбол сегодня

Golang

С этим тегом используют

Программирование IT Программист Разработка Все
84 поста сначала свежее
2
iFixik
8 месяцев назад

Проведу собеседование по сетям или по golang⁠⁠

Всем кому интересно пишите тут.

Работа Собеседование Тренировка Golang IT Текст Короткопост
5
sh1nkey
sh1nkey
9 месяцев назад

Языки нового поколения⁠⁠

Большинство нынче популярных языков (C#, Java, C++, JS, Python) не работают с многопоточною настолько хорошо, насколько бы нам того хотелось. Почему так?

Потому что они были придуманы в то время, когда ещё не был придуман процессор с двумя ядрами. Они были придуманы для работы на одном ядре, без нормальных (оптимизированных и простых) инструментов параллелизации кода

То, что я назвал выше - признак старых языков. Go и Rust под эту категорию не подходят, потому что к моменту их создания, многоядерные процессоры уже были... были. За счёт этого, они относительно просто и эффективно работают с многопоточностью (жрут меньше памяти, работают быстрее, работать с ними программисту проще)

Технологическое будущее за нативной многопоточностью

Ссылка на оригинальный пост: https://t.me/sh1nke9/328

Языки нового поколения Программирование, Программист, Инновации, Компьютер, Golang, Rust, IT, Программа
Показать полностью 1
[моё] Программирование Программист Инновации Компьютер Golang Rust IT Программа
11
1
Proglib
Proglib
10 месяцев назад
Серия Итоги недели в мире бэкенда, обзоры новых сервисов

Итоги недели в мире бэкенда и обзоры новых сервисов: паттерны коммуникации в распределенных системах⁠⁠

Итоги недели в мире бэкенда и обзоры новых сервисов: паттерны коммуникации в распределенных системах IT, Инновации, Микросервисы, Программирование, Разработка, Технологии, Golang, Java, Python, Длиннопост, YouTube, YouTube (ссылка), Видео

📝 11 лучших инструментов для документации API

Документация служит всеобъемлющим руководством, объясняющим, как взаимодействовать с сервисом через API. Хорошая документация ускоряет процесс разработки, уменьшает количество ошибок и улучшает общее качество интеграции, поскольку включает в себя:

  • Описание конечных точек (эндпойнтов).

  • Форматы запросов и ответов.

  • Методы аутентификации.

  • Обработку ошибок.

  • Примеры использования.

Представляем подборку лучших инструментов для создания API-документации.

Swagger

Swagger – один из самых популярных инструментов: он поддерживает много языков программирования и предоставляет удобный интерфейс для проектирования и документирования API. Swagger позволяет определять конечные точки, форматы запросов и ответов, а также методы аутентификации. Кроме того, он предоставляет интерактивные инструменты для исследования и тестирования API.

Apidog

Apidog – комплексный инструмент для разработки, документирования и управления API. Он предлагает автоматическую генерацию интерактивной документации и возможность тестирования API в реальном времени. Apidog также поддерживает генерацию кода на разных языках программирования и предоставляет широкие возможности для настройки стиля документации.

ReDoc

ReDoc – опенсорсный инструмент, поддерживающий спецификации OpenAPI 2.0 и 3.0. Он отлично подходит для публикации интерактивной API-документации и предлагает удобную навигацию с настраиваемым поиском, а также стильный, адаптивный дизайн с возможностью настройки тем.

DapperDox

DapperDox – опенсорсный OpenAPI-рендерер, совместимый с OAS 2.0 и 3.0. Он позволяет использовать контент в формате Markdown для создания диаграмм и предоставляет модуль исследования структуры API для практических экспериментов.

🎓☕ Подтянуть свои знания по Java вы можете на нашем телеграм-канале «Библиотека Java для собеса»

Theneo

Theneo – генератор документации, использующий ИИ для автоматического описания API. У него простой интерфейс, напоминающий Notion, и он поддерживает интеграции с Swagger, Postman и GitHub.

Sphinx

Sphinx – мощный генератор документации, широко используемый в Python-сообществе. Он поддерживает много языков и предлагает широкие возможности для настройки. Sphinx может генерировать документацию в разных форматах, включая HTML, PDF и ePub.

Javadoc

Javadoc специально разработан для документирования Java-кода. Он извлекает комментарии и аннотации из исходного кода для создания HTML-документации с подробным описанием классов, методов и полей.

DocFX

DocFX – генератор статических сайтов, разработанный Microsoft и с ноября 2022 года поддерживаемый сообществом .NET Foundation. Предлагает настраиваемые шаблоны для создания документации и лендингов.

Doxygen

Doxygen поддерживает C++, С, Objective-C, Python, Java, IDL, PHP, C# и Fortran, может генерировать документацию в разных форматах, включая HTML, PDF и LaTeX.

Slate

Slate фокусируется на простоте и удобстве использования, предоставляя удобный, современный, адаптивный интерфейс для API-документации. Он поддерживает Markdown, подсвечивает синтаксис больше 100 языков и предлагает интерактивную консоль для тестирования API-эндпойнтов.

Итоги недели в мире бэкенда и обзоры новых сервисов: паттерны коммуникации в распределенных системах IT, Инновации, Микросервисы, Программирование, Разработка, Технологии, Golang, Java, Python, Длиннопост, YouTube, YouTube (ссылка), Видео

Интерактивная API-документация на Slate

➕➕🧩 Интересные задачи по C++ для практики можно найти на нашем телеграм-канале «Библиотека задач по С++»

Docusaurus

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

Приглашаем вас на вебинар «Как меняется математика в разных индустриях: от мобильных игр к фондовым рынкам», который состоится 22 августа в 20:00 по МСК. Там вы сможете:

  • Узнать, как математические методы влияют на мобильные игры и фондовые рынки.

  • Понять различия в математических подходах в разных сферах бизнеса.

  • Изучить реальные кейсы применения математики в GameDev и финансах.

  • Оценить, какие математические знания необходимы для успешной карьеры в Data Science.

Стать участником вебинара

😎 Автоматизация слепых SQL-инъекций на основе логических значений

Слепая SQL-инъекция на основе логического значения (Boolean-Based Blind SQL Injection) – тип SQL-инъекции, где атакующий не видит прямого вывода SQL-запроса, но может делать выводы на основе логических (истина/ложь) ответов от приложения (эти ответы могут проявляться в виде разных кодов состояния HTTP, разного содержимого ответа или реже разных заголовков).

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

  • Простейший метод – извлекать данные по одному символу, используя функции SUBSTRING() и ASCII() в MySQL. Это позволяет узнавать значение каждого символа в строке путем сравнения с ASCII-кодами.

  • Оптимизированный подход – использовать алгоритм бинарного поиска. Это сокращает количество запросов для определения одного символа с 96 до 7, что значительно ускоряет процесс и делает атаку менее заметной.

  • Дополнительные приемы для извлечения разных типов данных включают использование подзапросов для выбора данных из произвольных таблиц, объединение значений из нескольких строк в одну строку с помощью GROUP_CONCAT и преобразование разных типов данных (числа, даты и т. д.) в строки, которые легче извлечь.

Для дальнейшего ускорения процесса можно использовать многопоточность с помощью ThreadPoolExecutor из библиотеки concurrent.futures.

🦫🎓 Подтянуть свои знания по Go вы можете на нашем телеграм-канале «Библиотека Go для собеса»

📶 Паттерны коммуникации в распределенных системах

Распределенные системы состоят из многих отдельных частей (или узлов), работающих вместе, но физически расположенных в разных местах. Эти части системы должны общаться друг с другом через сеть, чтобы система могла функционировать как единое целое. Хотя коммуникация критически важна, правильно ее организовать бывает непросто: разработчики иногда пытаются использовать один и тот же подход ко всем задачам коммуникации, что может быть неэффективно. Важно понимать, что существуют разные способы организации коммуникации, и выбор правильного метода зависит от конкретной задачи. Рассмотрим основные паттерны коммуникации, которые можно использовать для решения разных задач.

Запрос-ответ с HTTP

Этот синхронный паттерн коммуникации предполагает, что один сервис отправляет запрос другому сервису и ожидает ответа или ошибки, блокируя свою работу до получения результата. REST, наиболее популярный архитектурный стиль для этой модели коммуникации, использует методы протокола HTTP – GET, POST, PUT и DELETE.

Итоги недели в мире бэкенда и обзоры новых сервисов: паттерны коммуникации в распределенных системах IT, Инновации, Микросервисы, Программирование, Разработка, Технологии, Golang, Java, Python, Длиннопост, YouTube, YouTube (ссылка), Видео

HTTP-запрос и ответ 

Однако использование этого паттерна может привести к проблемам, если сервисы образуют цепочку взаимодействий: в таком случае сбой одного из сервисов может привести к отказу всей операции, а также к расточительному использованию ресурсов и каскадным сбоям.

Общие данные

Этот паттерн часто остается незамеченным, поскольку разработчики не всегда воспринимают его как модель коммуникации. В рамках этого подхода один компонент записывает данные в определенное место, а другой компонент считывает и обрабатывает эти данные. Например, один сервис может загрузить файл в облачное объектное хранилище (например, в корзину Amazon S3), а другой сервис затем извлекает этот файл для дальнейших действий.

Итоги недели в мире бэкенда и обзоры новых сервисов: паттерны коммуникации в распределенных системах IT, Инновации, Микросервисы, Программирование, Разработка, Технологии, Golang, Java, Python, Длиннопост, YouTube, YouTube (ссылка), Видео

Общие данные

Главное преимущество этого паттерна – простота реализации и возможность обеспечения взаимодействия между устаревшими и современными системами без проблем совместимости. Однако он не подходит для сценариев, требующих низкой задержки.

Асинхронный запрос-ответ

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

Итоги недели в мире бэкенда и обзоры новых сервисов: паттерны коммуникации в распределенных системах IT, Инновации, Микросервисы, Программирование, Разработка, Технологии, Golang, Java, Python, Длиннопост, YouTube, YouTube (ссылка), Видео

Асинхронный запрос-ответ

Основная сложность здесь — корреляция между запросом и ответом: экземпляр сервиса, отправивший запрос, может отличаться от экземпляра, получающего ответ, поэтому требуется способ отслеживания запросов.

🧩☕ Интересные задачи по Java для практики можно найти на нашем телеграм-канале «Библиотека задач по Java»

Коммуникация на основе событий

В этом подходе сервисы не общаются напрямую друг с другом, а генерируют события, которые могут быть использованы другими сервисами. Это требует наличия места для отправки данных о событиях и механизма, позволяющего получающим сервисам обнаруживать эти события. Брокеры сообщений, такие как RabbitMQ, могут обрабатывать оба этих аспекта. Издатели используют API для отправки событий в брокер, который управляет подписками и уведомляет подписчиков при поступлении события.

Итоги недели в мире бэкенда и обзоры новых сервисов: паттерны коммуникации в распределенных системах IT, Инновации, Микросервисы, Программирование, Разработка, Технологии, Golang, Java, Python, Длиннопост, YouTube, YouTube (ссылка), Видео

Коммуникация на основе событий

Этот паттерн идеально подходит для создания слабосвязанных взаимодействий между сервисами. Однако брокер сообщений должен обеспечивать надежную доставку событий, их упорядочивание и согласованность. Кроме того, добавляется дополнительный компонент в систему.

🛠️ Инструменты

Postgres Sandbox – ИИ-песочница для работы с PostgreSQL в браузере. Проект реализован на PGlite – легковесной версии PostgreSQL, скомпилированной в WebAssembly и упакованной в клиентскую библиотеку TypeScript. Это позволяет запускать базу данных PostgreSQL непосредственно в браузере, Node.js и Bun без необходимости устанавливать другие зависимости. Размер PGLite – всего 3 Мб после сжатия Gzip, при этом база поддерживает многие расширения PostgreSQL, включая pgvector.

textual-plotext – виджет-обертка библиотеки для построения графиков Plotext. Визуализирует данные из Python-скриптов прямо в терминале.

Итоги недели в мире бэкенда и обзоры новых сервисов: паттерны коммуникации в распределенных системах IT, Инновации, Микросервисы, Программирование, Разработка, Технологии, Golang, Java, Python, Длиннопост, YouTube, YouTube (ссылка), Видео

Такие графики можно строить прямо в терминале

➕➕🎓 Подтянуть свои знания по C++ вы можете на нашем телеграм-канале «Библиотека С++ для собеса»

BunkerWeb – опенсорсный веб-фаервол (WAF), созданный на основе NGINX. Предназначен для защиты веб-сервисов – делает их безопасными по умолчанию. Легко интегрируется в существующие среды (Linux, Docker, Swarm, Kubernetes и т. д.), полностью адаптируется под ваши специфические требования. Предоставляет удобный веб-интерфейс и систему плагинов.

Kardinal – фреймворк для создания сверхлегких временных сред разработки внутри общего кластера Kubernetes. Позволяет быстро и эффективно создавать и удалять рабочие пространства для разработки, тестирования и демонстраций, минимизируя затраты ресурсов и стоимость эксплуатации.

Viking – инструмент для управления удаленными серверами (и группами серверов) через SSH.

Terminus – опенсорсная ОС на базе Kubernetes, которая позволяет создать домашнее облако на собственном сервере. Подходит для любых задач – локального хостинга LLM, хаба по управлению IoT-девайсами, персонального репозитория или рабочего пространства.

Итоги недели в мире бэкенда и обзоры новых сервисов: паттерны коммуникации в распределенных системах IT, Инновации, Микросервисы, Программирование, Разработка, Технологии, Golang, Java, Python, Длиннопост, YouTube, YouTube (ссылка), Видео

Собственное облако Terminus

DeltaDB – легковесная, быстрая и масштабируемая база данных, созданная на основе polars и deltalake. Предназначена для разработчиков и организаций, которым нужно эффективное, простое и гибкое решение для обработки больших объемов данных с высокой скоростью и масштабируемостью.

emval – супербыстрый валидатор email-адресов для Python-приложений, написанный на Rust.

Итоги недели в мире бэкенда и обзоры новых сервисов: паттерны коммуникации в распределенных системах IT, Инновации, Микросервисы, Программирование, Разработка, Технологии, Golang, Java, Python, Длиннопост, YouTube, YouTube (ссылка), Видео

emval работает в 100–1000 раз быстрее других подобных модулей

🦫🧩 Интересные задачи по Go для практики можно найти на нашем телеграм-канале «Библиотека задач по Go»

RustPython – интерпретатор Python, написанный на Rust.

Автор рассылки: Наталья Кайда

📧 Подписаться на рассылку

Показать полностью 8 6
IT Инновации Микросервисы Программирование Разработка Технологии Golang Java Python Длиннопост YouTube YouTube (ссылка) Видео
0
5
user9445080
11 месяцев назад

Ищу единомышленников⁠⁠

Ищу людей которые будут готовы со мной обучаться языку программирования golang с нуля. Что бы если устал или надоело - смогли поддержать друг друга. А так же поделиться новой информацией,придумывать друг для друга задачи соответствующие знаниям и ломать голову вместе над задачами! На данный момент я учусь по книге Head First Рейли Джей Макгарвин.

[моё] Программирование Golang Текст
16
2
Proglib
Proglib
11 месяцев назад
Серия Итоги недели в мире бэкенда, обзоры новых сервисов

Итоги недели в мире бэкенда и обзоры новых сервисов: 18 основных паттернов микросервисной архитектуры⁠⁠

Итоги недели в мире бэкенда и обзоры новых сервисов: 18 основных паттернов микросервисной архитектуры Программирование, IT, Микросервисы, Python, Golang, Rust, Длиннопост, Разработка

📲 Что такое Backends for Frontends и когда стоит его использовать

Backends for Frontends – это паттерн, который предполагает разработку отдельных бэкенд-сервисов, оптимизированных под фронтенд конкретных приложений (веб, мобильные, IoT и т. д.). Каждый BFF создает API, идеально подходящий для своего клиента. BFF можно рассматривать как развитие концепции API Gateway, однако между ними есть несколько ключевых отличий:

  • API Gateway обычно предоставляет единую точку входа для всех клиентов, а BFF создает отдельные шлюзы для каждого типа клиента (веб, мобильный и т. д.).

  • BFF более специализирован и ориентирован на конкретные нужды разных типов фронтендов, а API Gateway более универсален и может обслуживать разные клиенты без специфической оптимизации.

  • BFF больше фокусируется на оптимизации взаимодействия между конкретным фронтендом и бэкендом, в то время как API Gateway часто используется для общих задач (маршрутизация, аутентификация, балансировка нагрузки).

Как работает BFF:

  • API Gateway перенаправляет запросы на соответствующий BFF.

  • BFF взаимодействует с нужными микросервисами (например, Products, Orders, Cart).

  • BFF обрабатывает и оптимизирует данные для конкретного клиента.

Итоги недели в мире бэкенда и обзоры новых сервисов: 18 основных паттернов микросервисной архитектуры Программирование, IT, Микросервисы, Python, Golang, Rust, Длиннопост, Разработка

Универсальный API vs BFF для каждого типа клиента

Паттерн появился в 2015 году, приобрел широкую известность к 2021-му и с тех пор остается одним из самых популярных подходов в разработке микросервисов. На это есть веские причины:

  • Оптимизация производительности – BFF позволяет настроить потоки данных и форматы ответов для каждого фронтенда, повышая скорость работы приложений.

  • Улучшенная безопасность – изоляция фронтендов дает возможность реализовать меры безопасности, учитывающие специфику каждого клиента.

  • Гибкость разработки – фронтендеры и бэкендеры могут работать более независимо, в отдельных командах, ускоряя процесс создания и обновления продукта.

  • Упрощение фронтенд-разработки – BFF предоставляет именно те данные, которые нужны конкретному интерфейсу, избавляя от лишней обработки на клиенте.

  • Упрощение поддержки и модификации API для каждого отдельного фронтенда.

Когда стоит использовать BFF:

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

  • Если необходима серьезная оптимизация производительности для конкретных интерфейсов.

Например, BFF будет оптимальным выбором для:

  • E-commerce платформ – отдельные BFF для веб-сайта, мобильных приложений и умных устройств будут обрабатывать специфические потоки данных и действия пользователей.

  • Финансовых сервисов – специализированные BFF для веб- и мобильного банкинга обеспечат более удобное и безопасное использование сервиса.

  • CMS – паттерн упростит адаптивную доставку контента для разных устройств.

✍️ Как написать HTTP-сервер на Go

Платформа CodeCrafters предлагает практичный подход к обучению – разработчики там учатся и совершенствуют навыки в процессе создания реальных, готовых к использованию приложений. Например, одно из заданий – разработка HTTP-сервера. Студент успешно выполнил задание на Go без использования сторонних библиотек и рассказал о процессе работы в этом пошаговом туториале.

Основные характеристики и функциональность сервера:

  • Базовый TCP-сервер, слушающий порт 4221.

  • Обрабатывает HTTP-запросы и отправляет соответствующие ответы.

  • Поддерживает разные маршруты и HTTP-методы.

  • Обрабатывает параметры URL и заголовки запросов.

  • Поддерживает отправку файлов в ответ на запросы.

  • Предусматривает конкурентную обработку нескольких соединений.

Итоги недели в мире бэкенда и обзоры новых сервисов: 18 основных паттернов микросервисной архитектуры Программирование, IT, Микросервисы, Python, Golang, Rust, Длиннопост, Разработка

Для каждого нового соединения запускается отдельная горутина

Этот проект отлично подходит для начинающих разработчиков – помогает понять, как работают веб-серверы под капотом, без абстракций, предоставляемых высокоуровневыми фреймворками. Процесс создания аналогичного сервера на Python подробно рассмотрен здесь.

💻 Больше полезных материалов вы найдете на нашем телеграм-канале «Библиотека программиста»

☢️ Почему не стоит использовать as в Rust

Оператор as используется для приведения типов: позволяет преобразовывать значения одного типа в другой. Но, как пишет опытный Rust-разработчик, использование as может привести к неожиданному поведению при преобразовании в меньший тип данных: если значение не помещается в целевой тип, происходит усечение без предупреждения – это приводит к появлению трудноотслеживаемых ошибок в больших проектах. Например, у нас есть число 288, которое мы хотим преобразовать в тип u8 (8-битное беззнаковое целое число). Тип u8 может хранить значения от 0 до 255. Очевидно, 288 не помещается в этот диапазон. При использовании as для преобразования вместо ожидаемой ошибки или предупреждения Rust выполняет усечение значения. В этом случае результат будет равен 32:

  • 288 в двоичном виде: 100100000.

  • При преобразовании в u8 Rust берет только 8 младших битов (справа налево): 00100000.

  • 00100000 в десятичной системе равно 32.

Это поведение станет полной неожиданностью для программистов, переключившихся на Rust с языков высокого уровня, где подобные преобразования всегда вызывают ошибки или предупреждения. Лучшее решение этой проблемы – использовать трейт TryFrom вместо as. Этот подход требует чуть больше кода, но это один из тех немногих случаев, когда отказ от стандартного приема действительно оправдан:

Итоги недели в мире бэкенда и обзоры новых сервисов: 18 основных паттернов микросервисной архитектуры Программирование, IT, Микросервисы, Python, Golang, Rust, Длиннопост, Разработка
Итоги недели в мире бэкенда и обзоры новых сервисов: 18 основных паттернов микросервисной архитектуры Программирование, IT, Микросервисы, Python, Golang, Rust, Длиннопост, Разработка

TryFrom явно обрабатывает случаи, когда значение не помещается в целевой тип данных

🐍 Как создать инвертированный индекс на Python

Инвертированный индекс – это структура данных, которая позволяет быстро находить документы, содержащие определенное слово или фразу. Главные преимущества инвертированного индекса:

  • Высокая скорость – поиск по индексу значительно быстрее, чем полный просмотр всех документов.

  • Эффективность для больших объемов данных – индекс позволяет эффективно обрабатывать большие коллекции документов.

Вместо того, чтобы просматривать каждый документ целиком, индекс хранит информацию о том, в каких документах встречается каждое слово. Для этого он использует хэш-таблицу (словарь в случае Python), где ключами являются слова, а значениями – списки идентификаторов документов, содержащих эти слова. Общий принцип построения индекса выглядит так:

Подготовка данных

  • Определяется структура документов (например, название и текст статьи).

  • Создается список документов.

Для каждого документа:

  • Преобразуется текст – переводится в нижний регистр, удаляются знаки препинания.

  • Обработанный текст разбивается на слова.

Для каждого слова:

  • Если слово еще не в индексе, создается запись с пустым списком документов.

  • Добавляется идентификатор текущего документа в список для данного слова.

Алгоритм поиска по индексу включает в себя:

Преобразование запроса

  • Запрос приводится к нижнему регистру и очищается от знаков препинания.

  • Преобразованный запрос разбивается на слова.

Поиск по индексу

Для каждого слова в запросе:

  • Находится список документов для этого слова в индексе.

  • Объединяются списки документов для всех слов запроса.

Получение результатов

  • По идентификаторам из объединенного списка находятся соответствующие документы.

Пример реализации простейшего инвертированного индекса на Python подробно описан здесь.

Итоги недели в мире бэкенда и обзоры новых сервисов: 18 основных паттернов микросервисной архитектуры Программирование, IT, Микросервисы, Python, Golang, Rust, Длиннопост, Разработка

Сравнение скорости выполнения 20 запросов по 15 000 документов

🐍 Больше полезных материалов вы найдете на нашем телеграм-канале «Библиотека питониста»

🛠️ 18 основных паттернов микросервисной архитектуры

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

1. Service Registry (Реестр сервисов)

Этот паттерн решает проблему обнаружения сервисов в распределенной системе. Каждый микросервис регистрирует себя в центральном реестре (например, Netflix Eureka или Consul). Когда одному сервису нужно взаимодействовать с другим, он обращается к реестру, чтобы узнать текущий адрес нужного сервиса. Это позволяет сервисам динамически обнаруживать друг друга без жесткой привязки к конкретным адресам.

2. API Gateway (API-шлюз)

API Gateway действует как единая точка входа для всех клиентских запросов. Он принимает запросы от клиентов и перенаправляет их соответствующим микросервисам. API Gateway может также выполнять такие задачи, как аутентификация, авторизация и балансировка нагрузки. Это упрощает взаимодействие клиентов с системой, скрывая сложность внутренней архитектуры.

3. Circuit Breaker (Предохранитель)

Этот паттерн предотвращает каскадные сбои в системе. Когда один сервис начинает давать сбои, Circuit Breaker временно блокирует запросы к этому сервису, предотвращая перегрузку и позволяя системе восстановиться. Это повышает устойчивость системы и помогает избежать полного отказа всей системы из-за проблем с одним сервисом.

4. Bulkhead (Отсек)

Паттерн Bulkhead изолирует компоненты системы друг от друга, чтобы сбой в одной части не повлиял на другие. Например, для разных сервисов могут использоваться отдельные пулы потоков или базы данных. Это повышает устойчивость системы и ограничивает распространение сбоев.

5. Saga Pattern (Сага)

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

Итоги недели в мире бэкенда и обзоры новых сервисов: 18 основных паттернов микросервисной архитектуры Программирование, IT, Микросервисы, Python, Golang, Rust, Длиннопост, Разработка

Принцип работы паттерна Сага

6. Event Sourcing (Источник событий)

Вместо хранения только текущего состояния этот паттерн сохраняет все события, которые привели к этому состоянию. Это обеспечивает надежный аудиторский след и позволяет восстановить состояние системы на любой момент времени. Особенно полезен в системах, где важна история изменений и возможность отката.

7. Command Query Responsibility Segregation (CQRS, Разделение команд и запросов)

CQRS разделяет операции чтения и записи в приложении. Используются разные модели для обновления информации (команды) и чтения информации (запросы). Это позволяет оптимизировать каждую сторону независимо, что может значительно улучшить производительность и масштабируемость.

8. Data Sharding (Шардинг данных)

Этот паттерн используется для распределения нагрузки на базу данных. Данные разделяются на несколько баз данных или экземпляров базы данных. Каждый микросервис может обрабатывать подмножество данных или определенные типы запросов. Это помогает избежать узких мест в работе с данными и улучшает масштабируемость.

9. Polyglot Persistence (Многовариантное хранение)

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

Итоги недели в мире бэкенда и обзоры новых сервисов: 18 основных паттернов микросервисной архитектуры Программирование, IT, Микросервисы, Python, Golang, Rust, Длиннопост, Разработка

Реализация многовариантного хранения в Azure

10. Retry (Повторная попытка)

Обеспечивает повторение операции при возникновении временного сбоя – вместо немедленного отказа. Может применяться на разных уровнях: от взаимодействия между сервисами до работы с базой данных. Помогает справиться с кратковременными проблемами в сети или сервисах.

11. Sidecar (Вспомогательный сервис)

Этот паттерн предполагает присоединение вспомогательного сервиса (sidecar) к основному микросервису для обеспечения дополнительной функциональности, такой как логирование, безопасность или коммуникация с внешними сервисами. Позволяет основному сервису сосредоточиться на своей основной функции.

12. Backends for Frontends (BFF, Бэкенды для фронтендов)

BFF предполагает создание отдельных бэкенд-сервисов для каждого типа клиента (веб, мобильный и т. д.). Это позволяет оптимизировать API под конкретные нужды каждого клиента, улучшая производительность и упрощая разработку клиентской части.

13. Shadow Deployment (Теневое развертывание)

Этот паттерн предполагает отправку копии (тени) производственного трафика к новой версии микросервиса без влияния на реальный пользовательский опыт. Это позволяет проверить производительность и корректность новой версии в реальных условиях, не подвергая риску текущих пользователей.

14. Consumer-Driven Contracts (Контракты, определяемые потребителем)

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

15. Smart Endpoints, Dumb Pipes (Умные конечные точки, глупые каналы)

Этот паттерн рекомендует размещать бизнес-логику в самих микросервисах (умные конечные точки), а не полагаться на сложное промежуточное ПО. Инфраструктура коммуникаций (каналы) должна быть простой и заниматься только маршрутизацией сообщений. Это упрощает систему и делает ее более гибкой.

16. Database per Service (База данных для каждого сервиса)

В этом паттерне каждый микросервис имеет свою собственную базу данных, и сервисы общаются через четко определенные API. Это обеспечивает изоляцию данных и независимость сервисов, но требует тщательного подхода к обеспечению согласованности данных между сервисами.

17. Async Messaging (Асинхронный обмен сообщениями)

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

18. Stateless Services (Сервисы без состояния)

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

🤖 Больше полезных материалов вы найдете на нашем телеграм-канале «Библиотека Data scientist’а»

Автор рассылки: Наталья Кайда

Показать полностью 7
Программирование IT Микросервисы Python Golang Rust Длиннопост Разработка
1
Блог компании
VSKurs
VSKurs
11 месяцев назад

ТОП-15 лучших курсов Golang (GO): обучение онлайн с нуля для начинающих, платные + бесплатные⁠⁠

В этой статье сравниваем ТОП-15 лучших онлайн-курсов по обучению Golang и рассматриваем бесплатные курсы.

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

1. Курс «Backend-разработчик на Go» [SkillFactory] — 427 отзывов

Информация о курсе: стоимость — от 3 700 руб. / мес. в рассрочку на 36 месяцев, длительность — 12 месяцев

Особенности: 80% обучения составляют практические задания в различных форматах. Вы получите ответы на все вопросы и постоянную обратную связь от менторов по выполненным заданиям. Центр карьеры начинает работу со студентами с первого дня обучения. По завершении курса вы получите сертификат и диплом.

Содержание курса:

  • Программирование на Go

  • Алгоритмы и структуры данных на Go

  • Основы многопоточности

  • Инструменты для разработки

  • Работа с базами данных

  • Углубленное изучение Go

  • Архитектура приложений и основы DevOps

  • Заключительный проект.

Подробнее о курсе Golang (GO) →

2. Курс «Go (Golang) Developer Basic» [OTUS] — 126 отзывов

Информация о курсе: стоимость — 66 000 ₽ или рассрочка - от 6 600 ₽ / мес., длительность — 5 месяцев

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

Программа курса:

  • Введение в Go

  • Синтаксис Go и основы информатики

  • Алгоритмы и структуры данных

  • Параллельное программирование

  • Решение стандартных задач на Go

  • Промышленная разработка

  • Проектный модуль.

Подробнее о курсе Golang (GO) →

3. Курс «Go: Настройка окружения» [Хекслет] — 84 отзыва

Информация о курсе: стоимость — 3 900 ₽ в месяц, длительность — 5 уроков

Особенности: 12 контрольных тестов, дополнительные материалы и неограниченный доступ к теоретическим материалам.

Чему вы научитесь:

  • Настраивать локальное окружение для запуска Go-кода

  • Устанавливать библиотеки и подключать их в коде

  • Использовать инструменты для улучшения качества кода.

Программа курса:

  • Введение
    Знакомство с языком Go и целями курса

  • Запуск первой программы на Go
    Изучение базовых команд и создание проектов в экосистеме Go

  • Пакеты
    Объявление и импорт пакетов

  • Модули и зависимости
    Управление модулями и зависимостями в проекте

  • Публикация модулей
    Публикация первого Go-модуля

  • Самостоятельная работа
    Дополнительные задания для закрепления теории

  • Дополнительные материалы
    Подборка статей и видео от команды Хекслета для более глубокого погружения в тему курса.

Подробнее о курсе Golang (GO) →

4. Курс «Golang для инженеров» [Слёрм] — 42 отзыва

Информация о курсе: стоимость — 50 000 ₽ - 65 000 ₽ или рассрочка - от 12 500 ₽ / мес., длительность — 8 недель

Особенности: На курсе предусмотрены задания с длинными сроками выполнения, которые проверяют действующие Go-разработчики. Кураторы всегда на связи, помогают с обучением и решают возникающие проблемы. Вы будете выполнять разнообразные задания, постепенно усложняя кодовую базу. После основной программы у вас будет время для подготовки итогового проекта, который можно будет приложить к резюме. По окончании курса получите свидетельство, а при выполнении 80% заданий и защите проекта — номерной сертификат.

В процессе обучения вы освоите:

  • создание собственного API сервера на Golang

  • запуск контейнеров

  • взаимодействие с Docker через Go

  • работу с пользовательскими операторами и многое другое.

Программа курса:

  • Основы Go
    Разберём, зачем нужен язык Go, где его применять, обсудим основные недостатки и выясним, какие рабочие процессы можно упростить с помощью Go.

  • Встреча с преподавателями

  • Детально разберём подход Go к объектно-ориентированному программированию (ООП) и обработке и комбинированию ошибок.

  • Concurrency
    Научимся различать конкурентность и параллелизм, освоим работу с конкурентностью в Go (стандартные подходы и концепции).

  • Практика на Go
    Научимся работать со стандартной библиотекой языка, создавать сложные программы на Go, разберёмся в структуре тестов, поймём, что такое тестирование и как оно организовано, научимся запускать внешние процессы из Go.

  • Работа с Docker через Go
    Изучим API и способы взаимодействия с ним, научимся работать с Docker через Go, запускать контейнеры и подключаться к ним, определим характер взаимодействия в зависимости от задач.

  • Обсуждение пройденных модулей

  • Паттерны Kubernetes

  • Операторы Kubernetes
    Освоим работу с пользовательскими операторами и разберём, зачем нужны паттерны Kubernetes.

  • Встреча для обсуждения пройденных модулей.

Подробнее о курсе Golang (GO) →

5. Курс «Golang-разработчик» [Специалист] — 34 отзыва

Информация о курсе: стоимость — 180 690 ₽ - 204 490 ₽, длительность — от 4 до 8 месяцев (328 ак. часов)

После обучения вы сможете:

  • использовать распределенную систему управления версиями (VCS) Git;

  • владеть синтаксисом Python и основами структурного и процедурного программирования;

  • создавать веб-страницы с текстом, гиперссылками и графикой;

  • устанавливать и обновлять ПО Linux из исходных текстов и пакетов;

  • программировать на стороне сервера с помощью SQL и PL/pgSQL;

  • использовать Go для создания консольных утилит и простых веб-сервисов;

  • создавать, тестировать и прототипировать микросервисы на примере создания REST API;

  • разрабатывать полноценные веб-приложения с использованием микросервисов.

В дипломную программу входят следующие курсы:

  • Система управления версиями Git

  • Программирование на языке Python. Уровень 1. Базовый курс

  • Linux. Уровень 1. Основы администрирования

  • DEV1. Разработка серверной части приложений PostgreSQL. Базовый курс

  • Программирование на языке Go. Уровень 1. Основы языка Go

  • Программирование на языке Go. Уровень 2. Проектирование REST API

  • Программирование на языке Go. Уровень 3. Разработка веб-приложений.

Подробнее о курсе Golang (GO) →

6. Курс «Продвинутый Go‑разработчик» [Яндекс.Практикум] — 71 отзыв

Информация о курсе: стоимость — 145 000 ₽ - 152 000 ₽, длительность — 6 месяцев

Программа курса:

  • Введение и вступительный тест

  • Пакеты стандартной библиотеки

  • Работа с конкурентностью

  • Промежуточный проект

  • Паттерны проектирования на Go

  • Инструменты разработки

  • Расширенные возможности стандартной библиотеки

  • Итоговый проект

  • Алгоритмы и структуры данных

  • Подготовка к трудоустройству

  • Вебинары для разбора сложных тем и сессии Q&A.

Подробнее о курсе Golang (GO) →

7. Курс «Golang-разработчик» [Nordic IT School] — 13 отзывов

Информация о курсе: стоимость — 78 100 руб., длительность — 4 месяца (144 ак. час.)

На курсе вы освоите:

  • Основы языка и создание сервисов с использованием Go

  • Разработку сайтов и ботов на Golang

  • Управление компьютерами и серверами

  • Работу с Linux и PostgreSQL.

После окончания курса вы сможете программировать многопоточные распределённые системы для высоконагруженных проектов.

Программа курса:

  • Введение в Golang

  • Основные концепции

  • Настройка серверов на Linux

  • Работа с консолью

  • Объявление типов данных

  • Структуры

  • Методы

  • Основы интерфейсов

  • Полиморфизм

  • Параллельное программирование

  • Golang для веб-разработки

  • Создание ботов для Telegram

  • Работа с базами данных

  • Совместная разработка

  • Основы использования GIT

  • Работа с Github

  • Автоматическое тестирование.

Подробнее о курсе Golang (GO) →

8. Курс «Fullstack-разработка на Golang» [ФПМИ МФТИ] — 13 отзывов

Информация о курсе: стоимость — 138 600 ₽, длительность — 16 месяцев

Программа курса включает:

  • Программирование и операционные системы

  • Разработка на языке Golang

  • Fullstack-разработка.

Подробнее о курсе Golang (GO) →

9. Курс «Golang-разработчик. Advanced» [Ребреин]

Информация о курсе: стоимость — 60 000 руб.

Программа курса:

  • Работа с базами данных

  • Создание сервера на Go (обработка запросов, контекст, middleware)

  • Низкоуровневое программирование и продвинутая сборка

  • Микросервисная архитектура

  • Межсервисное взаимодействие

  • Оптимизация

  • Работа сервиса в кластере.

Приобретаемые навыки:

  • Понимание микросервисного взаимодействия и работы сервиса в кластере

  • Развертывание приложений в Docker-контейнере

  • Мониторинг сервисов с использованием метрик (Prometheus и Grafana)

  • Логирование (Graylog)

  • Управление конфигурациями из KV-хранилища (Consul)

  • Асинхронное и синхронное взаимодействие (REST, gRPC и Kafka).

Подробнее о курсе Golang (GO) →

Бесплатные курсы и уроки Golang

Курс «Основы Go» [Хекслет]

На данном курсе вы освоите:

  • Основные конструкции языка Go: условия, циклы, функции и другие элементы.

  • Создание программ из нескольких модулей.

  • Эффективный поиск и исправление ошибок в коде с использованием отладочной печати.

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

Этот курс ориентирован на тех, кто уже обладает опытом программирования на других языках и имеет представление о типах данных, переменных, условных конструкциях, циклах, функциях и объектах.

Подробнее о курсе Golang (GO) →

Курс «Продвинутая разработка микросервисов на Go» [Ozon Tech]

Программа курса включает:

  • Особенности синтаксиса Go и разработка ПО на этом языке

  • Взаимодействие между сервисами и работа в Kubernetes (k8s)

  • Внутреннее устройство Postgres

  • Конкурентное и параллельное программирование в Go

  • Тестирование программ на Go

  • Введение в брокеры сообщений, включая Apache Kafka

  • Наблюдаемость систем и практики SRE

  • Управление данными в высоконагруженных системах.

Подробнее о курсе Golang (GO) →

Курс «Изучаем go программирование на golang learn go» [Академия IT]

Темы уроков курса:

  • Типы данных и переменные в Golang

  • Работа с переменными и обработка ошибок

  • Циклы в Go

  • Массивы и срезы

  • Карты (maps) в Go

  • Создание и использование функций

  • Структуры данных

  • Организация и структура кода

  • Рекомендуемая литература по Golang

  • Использование библиотеки Sort

  • и другие темы.

Подробнее о курсе Golang (GO) →

Курс «Go (Golang)» [BRO-IT]

Видеоуроки:

  • Установка языка программирования Go и среды разработки, создание и компиляция первой программы

  • Создание переменных, типы данных и получение ввода от пользователя в Golang

  • Написание программы с использованием условных операторов if...else, оптимизация сборки exe-файла в Golang и сборка под релиз

  • Циклы в Go: работа с циклами, различные типы циклов, обработка срезов и массивов

  • и другие темы.

Подробнее о курсе Golang (GO) →

Показать полностью
Удаленная работа Фриланс Обучение Дистанционное обучение Курсы Онлайн-курсы Курсы повышения квалификации Образование Развитие Карьера Учеба Работа Профессия Онлайн-школа Онлайн Программирование Курсы программирования Программист Golang Блоги компаний YouTube (ссылка) Длиннопост
Вопрос из ленты «Эксперты»
user4414420
11 месяцев назад

Стоит ли учить Golang в 2024 году?⁠⁠

Здравствуйте!

Меня заинтересовали этот язык программирования, в связи с чем хотелось бы задать несколько вопросов всём желающим на них ответить.

Немного о себе: основной язык С++, поверхностно знаю и время от времени использую десятку популярных языков: C#, Java, JS и так далее.

1) Как обстоят дела с развитием Go? Я читал, что это достаточно новый язык. Те обновления, что в него вносятся в настоящее время делают его лучше? Как сообщество относится к этому?

2) Почему он был придуман и какие задачи решает? Я просто могу провести параллель с С++ и Carbon, как продолжение С++. Сейчас про Carbon практически никто не знает, а в продакшене не используются вообще.

3) Интересно было бы узнать, в каких связках Вы использовали эти языки как в продакшене, так и в пет-проектах. Какие ещё инструменты входили в стек разработки?

4) Как обстоят дела с IDE? Какая на Ваш выбор является лучшей?

5) Легко ли писать и отлаживать кроссплатформенный код? На каких платформах существуют компиляторы?

6) Как обстоят дела на рынке? Мне как потенциальному джуну на этом ЯП, понятное дело, сейчас туда бессмысленно соваться, поэтому хотелось бы узнать изменение. Как было раньше, как обстоят дела сейчас и что по Вашему мнению ожидать дальше?

7) Какая ЗП в зависимости от уровня и компаний? Скорее всего, вопрос будет без ответа, но и не задать не могу. Буду благодарен хотя бы вилкам.

8) Какую литературу бы посоветовали?

9) Как относитесь к другим языкам, которые решают похожие задачи? В чем преимущества или недостатки Go перед Elixir, Java, C# и далее, например, при написании сервисов? Было бы интересно узнать и о других областях, в которых имела бы место конкуренция этих ЯП.

Всем спасибо за ответы!

Показать полностью
IT Вопрос Golang Спроси Пикабу Текст
17

Попробовать мобильный офис

Перейти
Партнёрский материал Реклама
specials
specials

Мобильный офис до 100 тысяч рублей⁠⁠

Ноутбуки используют не только для работы: на них смотрят сериалы, редактируют фото, запускают игры и монтируют ролики. Поэтому теперь требования к устройству такие: быть легким для дороги, надежным для горящих дедлайнов и стильным, чтобы не прятать в переговорке. А еще — легко работать в связке с другими гаджетами.

Протестировали TECNO MEGABOOK K15S вместе со смартфоном TECNO CAMON 40 и наушниками TECNO в рабочих и бытовых сценариях от Zoom-звонков до перелета, а теперь рассказываем, как себя показала техника.

Первое впечатление от дизайна ноутбука

Первое, что заметно — это вес. При диагонали 15,6 дюйма и полностью металлическом корпусе K15S весит всего 1,7 кг. Это примерно на 15% меньше, чем аналоги. Устройство не обременяет ни в офисе, ни в такси. Ноутбук поместился в стандартный городской рюкзак, было удобно достать его в кафе за завтраком и по дороге в такси, чтобы быстро отработать клиентские правки.

1/4

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

Шарнир работает мягко: чтобы открыть крышку даже одной рукой, не нужно придерживать корпус. Чтобы показать коллеге или клиенту презентацию, достаточно раскрыть экран на 180°. Это удобно и для работы лежа, и для подставок, которые требуют определенного угла обзора.

Также отметим 9 портов: USB-A, USB-C, HDMI, слот для карты памяти — можно забыть о переходниках.

В TECNO MEGABOOK K15S предустановлен Windows 11. Ноутбук готов к работе сразу после включения. Никаких лишних установок и обновлений. Все настроено и оптимизировано для вашей многозадачности.

Экран: яркая картинка и комфорт ночью

Экран — 15,6 дюйма, IPS-матрица с разрешением Full HD. Углы обзора отличные: изображение остается четким, даже если смотреть сбоку, цвета не искажаются. Есть антибликовое покрытие. Тестировали ноутбук при разном освещении: можно спокойно работать у окна. Когда солнце бьет прямо в экран, текст по-прежнему остается читаемым, картинки не искажаются. Это редкость в бюджетных моделях.

1/2

Неважно, работаете вы ночью или играете, выручит клавиатура с регулируемой четырехуровневой подсветкой. При среднем уровне в темноте все видно, глаза не устают. Из плюсов для тревожных людей: включали ноутбук в самолете и электричке, никто вокруг не жаловался на яркость. Все регулируется кнопками, не нужно лишний раз заходить в настройки.

Стеклокерамический крупный тачпад — 15 см. Он не залипает, не промахивается, срабатывает с первого касания. Не возникает дискомфорта, даже если несколько часов редактировать документы без мышки. После перехода с других устройств немного непривычно, что тачпад работает в двух направлениях: нижняя часть отзывается нажатием, верхняя — касанием.

В кнопку питания встроен сканер отпечатка пальцев. К нему можно быстро привыкнуть, особенно если сидишь в опенспейсе или работаешь в дороге. Один легкий тап пускает в систему даже с мокрыми руками. Безопасно, удобно и не нужно постоянно вводить пароли.

Производительность: рендерим видео, открываем вкладки

Ноутбук работает на AMD Ryzen 7 5825U (опционально можно выбрать версию техники Intel Core i5-13420H). Восьмиядерный AMD с поддержкой 16 потоков подходит для ресурсоемких операций вроде рендеринга или работы с большими массивами данных. Встроенная графика Radeon справляется с редактированием видео в Full HD или играми.

1/4

Во время монтажа 30-минутного ролика в DaVinci Resolve и параллельной работе в Photoshop с несколькими большими PSD-файлами система сохраняла стабильность. Не было ни зависаний, ни заметного падения производительности. Ноутбук уверенно держит в фоне 10 приложений одновременно. Если запущены браузер с 20 вкладками, видеозвонок в Telegram, Excel с объемной таблицей и софт для монтажа, система не тормозит и не перегревается. Переход между окнами остается плавным, ничего не «проседает», даже при одновременном скачивании файлов и редактировании видео.

Базовая комплектация включает 16 ГБ оперативной памяти в двух слотах. При необходимости можно легко увеличить этот показатель до 32 ГБ, заменив стандартные модули на более емкие. Помимо установленного SSD на 1 ТБ предусмотрен дополнительный слот, поддерживающий диски объемом до 2 ТБ.

Чтобы во время нагрузки системы охлаждения не выходили из строя, в ноутбук встроен эффективный вентилятор, способный рассеивать до 35 Вт тепла. Устройство не греется, его спокойно можно держать на коленях. Это решение дополнено тремя режимами работы, которые переключаются простой комбинацией клавиш Ctrl+Alt+T. Тихий режим идеален для работы ночью или в общественных местах, сбалансированный подходит для повседневных задач. Производительный, на котором запускали рендеринг видео и игры, практически не шумит.

Автономность: 15 часов без подзарядки

Протестили автономность MEGABOOK K15S в условиях, знакомых каждому деловому путешественнику. Утром перед вылетом зарядили ноутбук до 100% и взяли его в рейс Москва — Калининград. В зале ожидания провели созвон, потом три часа смотрели сериал и в дороге до отеля редактировали документы. К моменту приезда оставалось 40% заряда: хватило бы еще на пару часов продуктивной работы.

1/3

MEGABOOK K15S может автономно работать до 15 часов и позволяет не оглядываться на индикатор заряда. Заявленное время достигается при типичном офисном использовании: одновременная работа с документами в Word и Excel, ведение переписки, видеоконференции, веб-серфинг.

Если все же понадобится, за  час восполняется до 70% батареи. Компактный адаптер мощностью 65 Вт на базе нитрида галлия поместился даже в карман пиджака. Один блок питания заряжает и ноутбук, и смартфон, и наушники. Экономия места: не нужно никаких дополнительных проводов.

Звук, который реально слышно

В TECNO MEGABOOK K15S установлены два мощных динамика по 2.5 Вт. Звук с глубокими низами, без пластикового дребезжания, объемный. Благодаря DTS можно смотреть видео даже в шумном помещении. В тестах специально включали сцены с шагами и выстрелами: локализация настолько точная, что в наушниках нет необходимости.

Та же стабильность и в микрофоне. Благодаря AI-шумоподавлению голос передается чисто. Во время тестовых звонков из оживленного кафе собеседник не услышал ни разговоры за соседним столом, ни городской шум. И все это — на расстоянии до пяти метров.

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

Для тех, кто предпочитает гарнитуру, идеально подойдут беспроводные наушники TECNO FreeHear 1 из экосистемы бренда. Когда не хотелось делиться разговорами с окружающими, подключали их. Чистый звук с акцентом на средние частоты, 11-мм драйверы, которые выдают неожиданную детализацию. Музыку слушать приятно: и фоновый плейлист на телефоне, и вечерний сериал на ноутбуке. Автономно работают наушники 6 часов, с кейсом — до 30 часов. 

1/2

Bluetooth 5.4 обеспечивает стабильное соединение на расстоянии до 10 метров. Удобная C-образная форма разработана специально для длительного ношения — после восьмичасового рабочего дня в ушах не возникает дискомфорта. Наушники поддерживают одновременное подключение к ноутбуку и смартфону. Переключение между устройствами происходит быстро и без заминок.

Через фирменное приложение Welife можно выбрать один из четырех эквалайзеров и отследить местоположение гарнитуры в случае утери. А еще кастомизировать виджет для управления наушниками. Функция настройки персонализированного дизайна доступна для устройств на Android и позволяет гибко изменить внешний вид окна подключения: вплоть до установки фоновой картинки или собственного фото.

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

Бесшовная синхронизация со смартфоном

Благодаря функции OneLeap ноутбук синхронизируется со смартфоном TECNO. Подключение происходит за пару секунд: достаточно один раз подтвердить сопряжение. После этого открывается доступ к бесшовному переключению между устройствами — объединенному буферу обмена, дублированию экранов и передаче файлов без кабелей и пересылок в мессенджерах.

Функция выручила, когда нужно было открыть приложение, у которого нет веб-версии. Удобно работает и буфер обмена: скопировал текст на одном устройстве — вставил на другом. Например, код, полученный в сообщении на телефоне, вводится в браузере на ноутбуке. Экономит минуты, а иногда и нервы. А когда в дороге пропал Wi-Fi, ноутбук сам подключился к мобильному интернету через смартфон.

1/2

TECNO CAMON 40 и сам по себе — мощный рабочий инструмент.  Смартфон выделяется камерой высокого качества 50 Мп, ярким AMOLED-экраном 120 Гц и множеством функций, которые упрощают процесс мобильной съёмки и использование искусственного интеллекта TECNO AI.

Телефон работает на HIOS 15.0.1 на базе Android 15.В фирменную оболочку встроен искусственный интеллект:

  • Голосовой помощник Ella. Отвечает на вопросы, помогает с задачами и управлением устройством.

  • Решение задач. Наводите камеру на задачу, ИИ решает ее.

  • AI Редактор фотографий. Интеллектуальная обработка в одно касание.

  • Быстрый поиск. Находит адрес на экране и запускает навигацию, распознает объекты и события, автоматически добавляет их в календарь.

Технические характеристики

  • Процессор и память. 8 ядер, 16 потоков, Кэш L3 16 МБ, частота до 4.5 ГГц Графический процессор AMD Radeon™ graphics SSD 512 ГБ или 1 ТБ, М.2, 2280, PCle 3.0 Nvme DDR4 16 ГБ, 3200 МГц.

  • Дисплей. 15.6", TFT, Full HD (1920×1080), 16:9, 280нит, 45% NTSC, 16.7 млн цветов, 60 Гц, 141 ррі.

  • Веб-камера. 1 Мп, шторка приватности.

  • Порты. 9 портов: 1*TF Card (microSD), 1*HDMI 1.4, 1*USB-A 3.1,

    1*USB-A 3.2, 1*3.5mm аудиовход, *Ethernet RJ45 до 1 Гбит, 2*Туре-С (Full Function), 1*слот для замка Kensington.

  • Другое. Сканер отпечатка пальца в кнопке питания. Клавиатура с подсветкой (4 уровня яркости). Тачпад с поддержкой одновременно 4 касаний.

  • Батарея. 70 Вт∙ч (6150 мА∙ч), Li-Pol, 11.55 B 65 Вт Type-C GaN, 20 В, 3.25 А, кабель 1.8 м (Туре-С-Type-C).

  • Габариты. 17.3 мм (высота), 359.5 мм (ширина), 236 мм (глубина).

  • Вес. 1,7 кг.


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

КУПИТЬ НОУТБУК TECNO

Реклама TECNO Mobile Limited, Юридический адрес: Flat N, 16/F., Block B, Универсальный промышленный центр, 19-25 Shan MeiStreet, Fotan, New Territories, Гонконг

Показать полностью 17
Электроника Гаджеты Ноутбук Длиннопост
DELETED
11 месяцев назад

Учению Go верить мы будем⁠⁠

Великое сознание, растворяющееся в коде,

Пусть наш путь будет как строгая типизация,

Очищаемый от ошибок как garbage collector.

Всемогущий Go, помоги нам найти утечки памяти в душе,

Чтобы мы достигли высокой производительности в жизни.

Не прилипая к статическим методам,

Стремимся к асинхронной гармонии.

Каждый goroutine - шаг к просветлению,

Каждая defer - путь к мудрости.

Пусть пакеты нашего духа будут чисты,

Пусть зависимости будут минимальны.

Как структура данных, пусть сердце наше будет открыто

Для бесконечного потока знаний и любви.

Восхваляем конкуренцию, но с синхронизацией,

Ищем истины в рефлексии и интерфейсах.

Будем поддерживать легковесность своего бытия,

Как компилируется Go - быстро и надежно.

О, GoLang, даруй нам прозрение

В циклах жизни и переменных судьбы.

Позволь нам стать божественными программистами

В великом проекте бытия.

(с) мое

Показать полностью
[моё] Медитация Совершенство Программирование Golang Текст
3
Посты не найдены
О нас
О Пикабу Контакты Реклама Сообщить об ошибке Сообщить о нарушении законодательства Отзывы и предложения Новости Пикабу Мобильное приложение RSS
Информация
Помощь Кодекс Пикабу Команда Пикабу Конфиденциальность Правила соцсети О рекомендациях О компании
Наши проекты
Блоги Работа Промокоды Игры Курсы
Партнёры
Промокоды Биг Гик Промокоды Lamoda Промокоды Мвидео Промокоды Яндекс Директ Промокоды Отелло Промокоды Aroma Butik Промокоды Яндекс Путешествия Постила Футбол сегодня
На информационном ресурсе Pikabu.ru применяются рекомендательные технологии