• PostGIS и JPA

    • Tutorial


    PostGIS — открытое программное обеспечение, добавляющее поддержку географических объектов в реляционную базу данных PostgreSQL.

    В этой небольшой статье будет рассмотрено использование его в Java. В частности — задача нахождения географических объектов по их координатам.
    Читать дальше →
    • +11
    • 1,1k
    • 3
  • Важные изменения в работе CTE в PostgreSQL 12

      WITH w AS  NOT MATERIALIZED (
          SELECT * 
          FROM very_very_big_table
      )
      SELECT * 
      FROM w AS w1 
          JOIN w AS w2 
              ON w1.key = w2.ref
      WHERE w2.key = 123;

      Сегодня в репозиторий PostgreSQL упал комит, позволяющий управлять поведением обработки подзапросов CTE, а именно: теперь можно явно указывать, будет ли подзапрос материализовываться отдельно или же выполняться как часть одного большого запроса.


      Это войдет в PostgreSQL 12, и это big deal. Давайте рассмотрим, почему

      Читать дальше →
      • +40
      • 6,4k
      • 9
    • Работа с сервисом Managed Databases от Digital Ocean в .NET Core



        В том время, как у других облачных платформ уже давно есть свои решения для баз данных, Digital Ocean в этом сегменте до сегодняшнего дня ничего не предлагал. Но 14 февраля, в день всех влюбленных, компания решила сделать подарок своим клиентам и в режиме Limited Availability запустила сервис Managed Databases.

        Поскольку Digital Ocean сейчас является довольно популярной платформой для хостинга небольшой проектов на .NET Core, я не мог обойти вниманием это событие.

        Как работает сервис и какие есть нюансы при подключении к базе при использовании .NET Core в я расскажу в этой публикации.
        Читать дальше →
        • +12
        • 2,2k
        • 2
      • Повышение привилегий в PostgreSQL — разбор CVE-2018-10915

          КДПВ

          Не секрет, что стейт-машины среди нас. Они буквально повсюду, от UI до сетевого стека. Иногда сложные, иногда простые. Иногда security-related, иногда не очень. Но, зачастую, довольно увлекательны для изучения :) Сегодня я хочу рассказать об одном забавном случае с PostgreSQL — CVE-2018-10915, которая позволяла повышать привилегии до superuser.

          Читать дальше →
          • +40
          • 4,8k
          • 4
        • БД в облаках: кому и зачем — мнение специалистов Data Egret

            Есть мнение, что будущее за DB as Service. Стоит ли всем подряд увольнять DBA и переходить в публичное облако или стремиться создать приватное облако на Docker с Kubernetes? Трое экспертов из Data Egret — Алексей Лесовский, Виктор Егоров и Андрей Сальников — на канале #RuPostgres в прямом эфире поделились мнением, для каких именно проектов подойдут облачные модели.

            Модератором и ведущим беседы выступил Николай Самохвалов, основатель Postgres.ai и сооснователь сообщества RuPostgres.org.



            Под катом — расшифровка беседы.
            Читать дальше →
            • +34
            • 3,6k
            • 2
          • Дайджест новостей из мира PostgreSQL. Выпуск №14



              Мы продолжаем знакомить вас с самыми интересными новостями по PostgreSQL.

              Новости


              Microsoft приобрела Citus Data

              Безусловно, главная новость в мире PostgreSQL. Об этом есть сообщение на сайте Citus, равно как и на сайте MS.

              Postgres Pro Enterprise Certified

              СУБД Postgres Pro Enterprise получила сертификат ФСТЭК, и теперь в наборе Postgres Pro есть и «Сертифицированная версия Postgres Pro Enterprise». До этого сертификат, необходимый для работы с персональными данными, имела только Postgres Pro Standard («Сертифицированная версия Postgres Pro»). Подробности на сайте.

              credativ: PostgreSQL Competence Center

              Германская фирма credativ, до того известная в Европе и Азии, приобрела фирму OmniTI, чтобы выйти на американский рынок. credativ специализируется на развертывании и поддержке проектов open source. Теперь в США откроется PostgreSQL Competence Center, который будет заниматься высококритичными проектами и поддерживать БД в течение всего их жизненного цикла.
              Читать дальше →
            • Как мы побороли несовместимость при миграции данных с Greenplum 4 на Greenplum 5

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



                Дело в том, что файлы баз данных Greenplum версий 4 и 5 не совместимы между собой, и поэтому простой апгрейд от одной версии к другой невозможен. Миграцию данных можно провести только через выгрузку и загрузку данных. В этом посте я расскажу о возможных вариантах этой миграции.
                Читать дальше →
              • Клиент для «Сервер push сообщений»

                  Продолжение публикации «Сервер push сообщений»

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



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

                  Аналогично можно изменить ширину списка контактов и списка сообщений.

                  Отправка сообщений анимирована, какой либо анимации при отправке сообщений в других программах не было.

                  Для фона списка контактов используется градиент серого и розового, похожее сочетание можно встретить на небе в виде зарева.
                  Читать дальше →
                • Postgres в ретроспективе

                  • Перевод
                  Предлагаем вашему вниманию перевод статьи Джозефа Хеллерштейна «Looking Back at Postgres», опубликованной в соответствии с международной лицензией Creative Commons «С указанием авторства» версии 4.0 (CC-BY 4.0). Авторы оставляют за собой право распространять эту работу на личных и корпоративных веб-сайтах с надлежащей ссылкой на источник.

                  Перевод выполнен Еленой Индрупской. От себя добавлю, что «программист, который отчаянно хотел построить систему с многоверсионностью» — судя по всему, Вадим Михеев, ну а «добровольцев из России», переписавших GiST, мы все хорошо знаем.

                  Аннотация


                  Это воспоминание о проекте Postgres, выполняемом в Калифорнийском университете в Беркли и возглавляемом Майком Стоунбрейкером (Mike Stonebraker) с середины 1980-х до середины 1990-х годов. В качестве одного из многих личных и исторических воспоминаний, эта статья была запрошена для книги [Bro19], посвященной награждению Стоунбрейкера премией Тьюринга. Поэтому в центре внимания статьи — руководящая роль Стоунбрейкера и его мысли о дизайне. Но Стоунбрейкер никогда не был программистом и не мешал своей команде разработчиков. Кодовая база Postgres была работой команды блестящих студентов и эпизодически—штатных университетских программистов, которые имели немного больше опыта (и только немного большую зарплату), чем студенты. Мне посчастливилось присоединиться к этой команде в качестве студента в последние годы проекта. Я получил полезный материал для этой статьи от некоторых более старших студентов, занятых в проекте, но любые ошибки или упущения являются моими. Если вы заметили какие-либо из них, пожалуйста, свяжитесь со мной, и я постараюсь их исправить.
                  Читать дальше →
                  • +20
                  • 3,8k
                  • 1
                • Сервер push сообщений

                    В любом современном интернет сервисе можно выделить всего две основные функции:

                    • Первая — это авторизация пользователей.
                    • Вторая — это моментальная отправка некоего события с сервера на клиент.

                    Первый пункт, думаю, в пояснении не нуждается.

                    Второй пункт, это клиент серверная технология, но наоборот. Клиент не делает периодически запрос на сервер — есть ли новые сообщения. Сервер, при появлении некоего события, отравляет сообщение сразу клиенту.

                    Для лучшего понимания сервис не некий сферичный в вакууме. Сервис можно представить как:

                    • Папка с файлами в облаке. Информация о изменении, добавлении и удалении пересылается другим пользователям или текущему пользователю, но на другие устройства.
                    • Компьютерная программа чтения логов сервера, при появлении записей «error» отсылающая содержимое записи пользователю на мобильный телефон.
                    • Видео-глазок (камера), делающий снимки при движении около двери квартиры.
                    • Сервис получающий телеметрию из приложения android-auto.
                    • Похожий на предыдущий пункт сервис, позволяющий узнать дошел ли ребенок до школы или пришел из школы домой.

                    Список можно расширять до бесконечности, приведены, как пример, лишь наиболее известные варианты использования.

                    Практически все приведенные примеры сервисов можно представить в виде «мессенджера». Часть из примеров именно так и описывалась, видел статьи, как подключить камеру и отправлять снимки в один известный мессенджер.

                    Не так давно была статья что за сервисом камер в дверных глазках, вместо искуственного интелекта наблюдали посторонние люди. Не буду заострять внимание на бесплатных сервисах от больших «добрых» корпораций. Как говориться в известной пословице «Бесплатный сыр бывает в мышеловке» и руководствуясь другой пословицей «Своя рубашка ближе к телу», свой «сервис» лучше.

                    Код скриптов сервера открыт и бесплатен


                    Читать дальше →

                  Самое читаемое