Avito на GopherCon Russia 2018

в 12:17, , рубрики: avitoquiz, Go, golang, Блог компании Avito, конференции, Программирование

Всем привет! В марте в московском Технополисе прошла конференция, посвященная языку программирования Go — GopherCon Russia 2018. На ней прозвучали выступления от core-team — было круто услышать из первых уст о том, как нужно делать правильно. И конечно, не обошлось без докладов про микросервисы, опентрейсинг, работу с сетью в Go, создание клиентских библиотек и крутых инструментов.
Хотим сказать «спасибо» выступающим — за доклады и организаторам — за возможность пообщаться с живым Бредом Фитцпатриком и настоящей Эшли МакНамара. Под катом рассказываем о докладах, мастер-классах и конкурсе от Avito, а также разыгрываем немного Go-сувенирки.

Avito на GopherCon Russia 2018 - 1

Большинство фото мы взяли из отчета, выложенного на странице GopherCon Russia 2018 в Facebook.

Доклады & секции от Avito

Строим поисковую экосистему на Go

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

Avito на GopherCon Russia 2018 - 2

Поиск на миллион

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

Несмотря на небольшие проблемы с подключением компьютера на мастер-классе было много людей. Большая часть смогла написать свой поиск на фреймворке riot, загрузить в него миллион новостных заголовков и получить в подарок наклейки от Авито). Трое самых активных помимо основной задачи решили несколько дополнительных: провели свой бенчмарк и реализовали кастомный ранкер. Я буду рад, если в итоге больше людей изучат riot и, возможно, законтрибьютят в него, чтобы он развивался быстрее.

Centrifugo 2

В рамках секции внутри Avito-комнаты Александр Емелин рассказывал о планах дальнейшего развития проекта Centrifugo. Последние несколько месяцев он работал над второй версией сервера, позволяющего обслуживать тысячи одновременных подключений от пользователей приложения и отправлять им сообщения в режиме реального времени (Websocket и SockJS). Важной особенностью сервера является то, что он позволяет интегрироваться с бекендом, написанным на любом языке программирования.

Во второй версии были реализованы достаточно сложные задачи — например, ядро сервера было выделено в отдельную библиотеку, которую смогут использовать Go-разработчики. Реализована поддержка передачи бинарных данных по Websocket (Protobuf) в дополнение к имеющемуся JSON-протоколу, а также реализована поддержка GRPC в качестве альтернативного транспорта.

Вот что рассказал Александр после мастер-класса:

В Avito-комнату пришло достаточно много людей, среди которых были и текущие пользователи Centrifugo. Получилось получить ценный фидбек, что чрезвычайно важно на данной стадии разработки. После устного рассказа про особенности второй версии посмотрели на небольшой real-time пример, использующий эту библиотеку — очень простой чат с интересной особенностью: сервер позволял клиентам использовать не только протокол Websocket в качестве транспорта, но и GRPC.

Golang, или Туда и Обратно

На нашем стенде, конечно, тоже целый день было людно. Уже в ∞ утра мы ждали самых ранних участников конференции. Можно было сфотографироваться с Гофером…

Avito на GopherCon Russia 2018 - 3

… Или бравым сотрудником нашего отдела технопиара Гошей Бессмертным, который совсем недавно был принят в штат младшим специалистом (правда, пока только в качестве инвентарного номера)...

Avito на GopherCon Russia 2018 - 4

Ну и самая, пожалуй, интересная активность — весь день на нашем стенде проходил конкурс «Golang, или Туда и Обратно», где можно выиграть футболку, варежки или стикерпак с символикой Go. Нужно было сопоставить сниппеты кода, написанного на Golang и других языках программирования. Если приглядеться, то можно увидеть, как примерно половина запечатлённых на этом снимке участников конференции вовсю матчит сниппеты:

Avito на GopherCon Russia 2018 - 5

А вот планы покрупнее:

Avito на GopherCon Russia 2018 - 6

И немножко — в залах докладов:

Avito на GopherCon Russia 2018 - 7

Кажется, что игра «зашла» всем участникам: те, кто участвовал в конкурсе, с удовольствием размяли мозги перед докладами и в перерывах между ними, а мы получили удовольствие от общения с каждым из примерно 350 участников этой игры.

Розыгрыш стикерпаков и Go-варежек на Хабре

У нас осталось некоторое количество Go-варежек и стикерпаков — их мы хотим разыграть здесь, на Хабре. Что внутри набора наклеек? Девять «базовых» гоферов…

Avito на GopherCon Russia 2018 - 8

… и набор наклеек-аксессуаров к ним для того, чтобы вы могли собрать своего собственного гофера. Например, так:

Avito на GopherCon Russia 2018 - 9

Для этого предлагаем вам посмотреть и сопоставить сниппеты кода, написанного на Golang и других языках программирования. И написать в комментариях пары по принципу 1 — A, 2 — B и так далее. Прячьте ответы под спойлер, чтобы не портить другим фан!

Первым пяти комментаторам мы пришлём по Go-стикерпаку и паре варежек почтой или курьером. Ещё пять таких же наборов распределим между оставшимися участниками с помощью рэндомайзера. Enjoy!

Развернуть примеры кода

1
Avito на GopherCon Russia 2018 - 10

2
Avito на GopherCon Russia 2018 - 11

3
Avito на GopherCon Russia 2018 - 12

4
Avito на GopherCon Russia 2018 - 13

5
Avito на GopherCon Russia 2018 - 14

6
Avito на GopherCon Russia 2018 - 15

7
Avito на GopherCon Russia 2018 - 16

8
Avito на GopherCon Russia 2018 - 17

9
Avito на GopherCon Russia 2018 - 18

10
Avito на GopherCon Russia 2018 - 19

A

type vertex struct {
        X, Y int
}

func f(v *vertex) {
        v.X = 3
        v.Y = 4
}

func main() {
        v1 := vertex{1, 8}
        f(&v1)
}

B

package main

import "fmt"
import "math"

func main() {
        fmt.Printf("%f", 1.0/math.Sqrt(49))
}

C

package main

import (
    "fmt"
    "unicode/utf8"
)

func main() {
    b := []byte{80, 72, 80, 32, 114, 117, 108, 101, 115}
    for len(b) > 0 {
        r, size := utf8.DecodeRune(b)
        fmt.Printf("%c", r)
        b = b[size:]
    }
}

D

func f(x, y int64) int64 {
   return x + y
}

E

package main

import (
        "fmt"
)

func f(a int) func(b int) int {
        return func(b int) int {
                return a*b
        }
}

func main() {
        list := []int{2, 2, 2, 2}
        g := f(3)
        for i, value := range list {
                list[i] = g(value)
        }
        fmt.Println(list)
}

F

type vt struct {
        X, Y int
}

func f(v vt) {
        v.X = 3
        v.Y = 4
}

func main() {
        v1 := vt{1, 8}
        f(v1)
}

G

package main

import (
        "io"
        "log"
        "net/http"
)

func h(w http.ResponseWriter, r *http.Request) {
        io.WriteString(w, "hello, world!n")
}

func main() {
        http.HandleFunc("/", h)
        log.Fatal(http.ListenAndServe(":8080", nil))
} 

H

type filter func(string) bool

func bf(list []string, fn filter) [][]string {
        valid, invalid := []string{}, []string{}

        for _, s := range list {
                if fn(s) {
                        valid = append(valid, s)
                } else {
                        invalid = append(invalid, s)
                }
        }

        return [][]string{valid, invalid}
}

func main() {
        l := []string{"gl", "hf", "ht", "tt"}

        res := bf(l, func(s string) bool {
                return s[0] == 'h'
        })
}

I

package main

import "fmt"

func main() {
        a, b := 5, 10
        fmt.Println(map[bool]int{true: a, false: a-1}[a > b])
}

J

package main

import (
        "fmt"
)

func f(a, b int) int {
        if a > b {
                return a
        }

        return b
}

func main() {
        ints := []int{1, 8, 3, 4, 5}
        res := ints[0]

        for _, v := range ints {
                res = f(res, v)
        }

        fmt.Println(res)
}

Ждём ваших комментариев! А Гофер пока отдыхает после конференции и набирается сил перед следующей.

Avito на GopherCon Russia 2018 - 20

До новых встреч!

Автор: rafinirovannoe

Источник

* - обязательные к заполнению поля


https://ajax.googleapis.com/ajax/libs/jquery/3.4.1/jquery.min.js