Upgrade to Pro — share decks privately, control downloads, hide ads and more …

Rails Girls Varna 2.0 August 2016

Rails Girls Varna 2.0 August 2016

Slides for the Rails Girls Varna 1.0 event, which took place on 14th August 2016. http://railsgirls.com/varna-2016-august

Dimitar Dimitrov

August 14, 2016
Tweet

More Decks by Dimitar Dimitrov

Other Decks in Programming

Transcript

  1. Rails Girls! • Тръгва от Финландия, инициирано от две дами

    • Първото събитие е ноември 2010 г. • Над 100 са заявилите участие
  2. Rails Girls! • Тръгва от Финландия, инициирано от две дами

    • Първото събитие е ноември 2010 г. • Над 100 са заявилите участие • Много събития по целия свят след това
  3. WiFi & WC 1. Мрежа RailsGirls (без парола) 2. Ползвайте

    5 GHz, ако я виждате 3. Не закачайте телефоните си
  4. WiFi & WC 1. Мрежа RailsGirls (без парола) 2. Ползвайте

    5 GHz, ако я виждате 3. Не закачайте телефоните си 4. Изключете си Dropbox, Skype, uTorrent и подобни
  5. Не бързайте; има време. Задавайте въпроси. Много. Обяснявайте си неща

    взаимно. Бъдете максимално непредубедени. Забавлявайте се :)
  6. Записки? • Ще ви изпратим презентацията • Ще ви засипем

    с линкове и напътствия • Записвайте си въпроси, термини, неща за обяснение по-късно, интересни моменти
  7. Записки? • Ще ви изпратим презентацията • Ще ви засипем

    с линкове и напътствия • Записвайте си въпроси, термини, неща за обяснение по-късно, интересни моменти • Винаги може да питате инструктора си или нас за нещо
  8. Термини • Ще има много, които няма да знаете. •

    Питайте за всички. Трябва ви само груба представа кое какво е. Не е нужно да помните всичко.
  9. Термини • Ще има много, които няма да знаете. •

    Питайте за всички. Трябва ви само груба представа кое какво е. Не е нужно да помните всичко. • Понякога не се усещаме, когато ползваме термини. Помогнете ни.
  10. 1. 10:30 – 13:00 Уъркшоп 1 (инструменти, HTML, CSS, основи

    на програмиирането) 2. 13:00 – 13:30 Обяд (тук, от спонсорите)
  11. 1. 10:30 – 13:00 Уъркшоп 1 (инструменти, HTML, CSS, основи

    на програмиирането) 2. 13:00 – 13:30 Обяд (тук, от спонсорите) 3. 13:30 – 13:45 Кратка игра и томбола
  12. 1. 10:30 – 13:00 Уъркшоп 1 (инструменти, HTML, CSS, основи

    на програмиирането) 2. 13:00 – 13:30 Обяд (тук, от спонсорите) 3. 13:30 – 13:45 Кратка игра и томбола 4. 13:45 – 16:00 Уъркшоп 2
  13. Езици за програмиране • Ruby (Руби) е език за програмиране

    • Има и други (C#, Java, C++, PHP, JavaScript, Clojure, Scheme и още 2783...)
  14. Езици за програмиране • Ruby (Руби) е език за програмиране

    • Има и други (C#, Java, C++, PHP, JavaScript, Clojure, Scheme и още 2783...) • Можем да ползваме произволен* език, за да правим това, което ще правим днес
  15. Езици за програмиране • Ruby (Руби) е език за програмиране

    • Има и други (C#, Java, C++, PHP, JavaScript, Clojure, Scheme и още 2783...) • Можем да ползваме произволен* език, за да правим това, което ще правим днес • Ruby е готин и ще ползваме него
  16. Езици за програмиране • Ruby (Руби) е език за програмиране

    • Има и други (C#, Java, C++, PHP, JavaScript, Clojure, Scheme и още 2783...) • Можем да ползваме произволен* език, за да правим това, което ще правим днес • Ruby е готин и ще ползваме него • Може да си изкарвате прехраната с
  17. Речник • Сървър – компютър, закачен за интернет • (Уеб)

    сървър – помощна програма • Клиент – браузърът на потребителя
  18. Речник • Сървър – компютър, закачен за интернет • (Уеб)

    сървър – помощна програма • Клиент – браузърът на потребителя • Интернет – компютри, свързани един с друг
  19. Речник • Сървър – компютър, закачен за интернет • (Уеб)

    сървър – помощна програма • Клиент – браузърът на потребителя • Интернет – компютри, свързани един с друг • Уебсайт – HTML + CSS + картинки + …, преточващи се от сървъра към клиента
  20. Статични vs. динамични сайтове • Статични — едно и също,

    во веки веков • Динамични — шаблони, попълвани с данни; може и да има интеракция с потребител, може и да няма
  21. Статични vs. динамични сайтове • Статични — едно и също,

    во веки веков • Динамични — шаблони, попълвани с данни; може и да има интеракция с потребител, може и да няма • Приложението, което ще правим днес, попада във втората категория
  22. Статични vs. динамични сайтове • Статични — едно и също,

    во веки веков • Динамични — шаблони, попълвани с данни; може и да има интеракция с потребител, може и да няма • Приложението, което ще правим днес, попада във втората категория • И за двата вида имаме нужда от помощната програма “сървър” и от компютър, на който тя да работи
  23. Как разработваме сайт? • Обикновено имаме “локално” копие • Файлове,

    код, картинки + сървър + БД • Редактираме си кода и файловете локално
  24. Как разработваме сайт? • Обикновено имаме “локално” копие • Файлове,

    код, картинки + сървър + БД • Редактираме си кода и файловете локално • Разглеждаме си промените локално
  25. Как разработваме сайт? • Обикновено имаме “локално” копие • Файлове,

    код, картинки + сървър + БД • Редактираме си кода и файловете локално • Разглеждаме си промените локално • Когато сме готови, копираме новия код, картинки, файлове на реалния сървър
  26. Как разработваме сайт? • Обикновено имаме “локално” копие • Файлове,

    код, картинки + сървър + БД • Редактираме си кода и файловете локално • Разглеждаме си промените локално • Когато сме готови, копираме новия код, картинки, файлове на реалния сървър
  27. Динамични уеб сайтове • Още — приложения (applications, apps) •

    За тях имаме нужда от “логика” на сървър
  28. Динамични уеб сайтове • Още — приложения (applications, apps) •

    За тях имаме нужда от “логика” на сървър • “Логика” = програма, написана на език за програмиране
  29. Динамични уеб сайтове • Още — приложения (applications, apps) •

    За тях имаме нужда от “логика” на сървър • “Логика” = програма, написана на език за програмиране • Ще се забавляваме с това днес, използвайки Ruby
  30. Sinatra • Sinatra е името на една купчина код (“фреймуърк”),

    която някой е написал вместо нас, за да ни улесни в направата на уеб приложения
  31. Sinatra • Sinatra е името на една купчина код (“фреймуърк”),

    която някой е написал вместо нас, за да ни улесни в направата на уеб приложения • Можем да я ползваме безплатно
  32. Sinatra • Sinatra е името на една купчина код (“фреймуърк”),

    която някой е написал вместо нас, за да ни улесни в направата на уеб приложения • Можем да я ползваме безплатно • Sinatra има някои неща, вградени в него, вкл. и (уеб) сървър
  33. Sinatra • Sinatra е името на една купчина код (“фреймуърк”),

    която някой е написал вместо нас, за да ни улесни в направата на уеб приложения • Можем да я ползваме безплатно • Sinatra има някои неща, вградени в него, вкл. и (уеб) сървър • Можем и без Sinatra, но ще се поизпотим повече
  34. Раждането на едно приложение • Звучи сложно, но не е

    • Най-важното — • Започвате с малки стъпки и надграждате на итерации
  35. Раждането на едно приложение • Звучи сложно, но не е

    • Най-важното — • Започвате с малки стъпки и надграждате на итерации • Експериментирате и грешите
  36. Раждането на едно приложение • Звучи сложно, но не е

    • Най-важното — • Започвате с малки стъпки и надграждате на итерации • Експериментирате и грешите • Подобрявате и повтаряте цикъка
  37. • Опознайте инструментите си — конзола, текстов редактор, браузър •

    Поиграйте си с Ruby в irb и с микро-програмки • След това HTML + CSS • http://bit.ly/railsgirlsvarna2 + http://bit.ly/cheat-rails • http://www.sinatrarb.com/intro.html • URL-и, HTTP и цикълът на един request Уъркшоп 1
  38. HTML AJAX CSS RUBY, PYTHON, PHP, SCALA MYSQL, MONGODB RUBY

    ON RAILS, DJANGO, CAKEPHP, JETTY , LIFT…. XML JAVASCRIPT DOM UNICORN Friday, March 23, 12
  39. Etsy: “We use a number of different programming languages (including

    Matlab!) but are primarily a PHP shop. We have a number of databases, some of which are MySQL and some of which are PostgreSQL. “ Friday, March 23, 12
  40. 8 Foursquare: “Server code is written in scala running on

    the lift web framework using jetty for a webserver. We front everything with nginx, and use HAProxy in between. MongoDB handles most of our data storage needs (though a bit hasn't been migrated off PostgreSQL yet). Friday, March 23, 12
  41. R #1 PHP #2 SaaS #3 RoR #4 HTML #5

    MongoDB Rules: Figure out the term and place it on the bentobox in the right place.. There might be false friends and doubles. Googling allowed! You have five minutes – wrong answers will be removed, the team with most post-its wins! #6 Apache #7 CSS #8 Django #9 MySQL #10 nginx Friday, March 23, 12
  42. R #1 PHP #2 SaaS #3 RoR #4 HTML #5

    MongoDB #6 Apache #7 CSS #8 Django #9 MySQL #10 nginx Logic. PHP is a very popular language designed to produce dynamic Web pages. It goes well with HTML. - What makes PHP special? - Why it’s so popular? No where. Software as a service. Not a technical term - more a business/delivery model, in which software is hosted centrally, not by the user themselves and they often pay a subscription fee. Examples range from Salesforce, Spotify, Google Docs.. - What other buzzwords are there that are not technical? Logic. Ruby on Rails. Sometimes abbreviations might fool you! Style & structure. Especially structue: HTML is what describes the structure and the (static) content of the website. - What is XHTML? HTML5? - Scripting language vs. markup? Database. An open source database system. Stores the web app data in a little different way than MySQL, making it easier and faster for certain types of apps. - What are noSQLs? Why is MongoDB so popular? Infrastructure. A popular open source HTTP server software. Servers can be hardware or software - here we’re focusing on the latter. Servers are the piece of software that deliver the web page to you. - What is HTTP? What is the role of the browser? Style and structure. Especially style, designed to describe the look of webpages, including elements such as the layout, colors and fonts. - Why is CSS important when building bigger sites? - What is CSS3? Logic. A similar framework as Rails is for Ruby, Django is for Python. - What other examples of popular frameworks are there? For Ruby? Database. Worlds most popular open source database system, used by Facebook, Twitter, Wordpress etc. Well baked into many software stacks like LAMP - Talk about LAMP and other software stacks - Talk a little about open source Infrastructure. Pronounced “Engine X”. An open source HTTP server. Said to be faster than Apache - in many ways like MongoDB is for MySQL. - What are proxies? - Talk about Friday, March 23, 12
  43. Уъркшоп 2 • http://bit.ly/railsgirlsvarna2 + http://bit.ly/cheat-rails • http://www.sinatrarb.com/intro.html • Изгледи;

    шаблони; ERB (embedded Ruby и HTML) • Бази от данни – “Big data is when Excel crashes…” • Външни библиотеки (gems) и управлението им.
  44. Как да продължим? 1. Продължете да пишете (код) 2. Работете

    над нещо реално 3. Поддържайте връзка помежду си
  45. Как да продължим? 1. Продължете да пишете (код) 2. Работете

    над нещо реално 3. Поддържайте връзка помежду си 4. Забавлявайте се!
  46. Study групи • Седмични срещи в местния хакерспейс • Ще

    има поне един инструктор • Без “домашна” работа • Трупаме реални знания чрез практика • С начинаещи ще се започва от нулата
  47. Study групи • Поне един ден седмично, след 19:30 •

    Малки групи - няколко човека • Не е фатално, ако понякога изпускате • Ако има повече желаещи, ще се измисли • Доброволни и безплатни
  48. Study групи • Напълно възможно е да се научите •

    Няма тайна – трябва да отделяте време • Ще получавате помощ, но трябва да сте мотивирани да изкачите планината сами
  49. Благодарности • На целия организационен екип • На екипа на

    VarnaConf, домакините и спонсорите и партньорите ни
  50. Благодарности • На целия организационен екип • На екипа на

    VarnaConf, домакините и спонсорите и партньорите ни • На всички инструктори
  51. Благодарности • На целия организационен екип • На екипа на

    VarnaConf, домакините и спонсорите и партньорите ни • На всички инструктори • На вас!