Table of Contents for
Magento 2 - Build World-Class online stores

Version ebook / Retour

Cover image for bash Cookbook, 2nd Edition Magento 2 - Build World-Class online stores by Jonathan Bownds Published by Packt Publishing, 2017
  1. Cover
  2. Table of Contents
  3. Magento 2 - Build World-Class online stores
  4. Magento 2 - Build World-Class online stores
  5. Credits
  6. Preface
  7. 1. Module 1
  8. 1. Magento Fundamentals
  9. XAMPP installation
  10. Magento
  11. Summary
  12. 2. Magento 2.0 Features
  13. An introduction to the Magento order management system
  14. Magento 2.0 command-line configuration
  15. The command-line utility
  16. Summary
  17. 3. Working with Search Engine Optimization
  18. Store configuration
  19. SEO and searching
  20. SEO catalog configuration
  21. Google Analytics tracking code
  22. Optimizing Magento pages
  23. Summary
  24. 4. Magento 2.0 Theme Development – the Developers' Holy Grail
  25. Magento 2.0 theme structure
  26. The Magento Luma theme
  27. Magento theme inheritance
  28. CMS blocks and pages
  29. Custom variables
  30. Creating a basic Magento 2.0 theme
  31. Summary
  32. 5. Creating a Responsive Magento 2.0 Theme
  33. Composer – the PHP dependency manager
  34. Building the CompStore theme
  35. CSS preprocessing with LESS
  36. Applying new CSS to the CompStore theme
  37. Creating the CompStore logo
  38. Applying the theme
  39. Creating CompStore content
  40. Customizing Magento 2.0 templates
  41. Summary
  42. 6. Write Magento 2.0 Extensions – a Great Place to Go
  43. Using the Zend framework
  44. Magento 2.0 extension structure
  45. Developing your first Magento extension
  46. The Twitter REST API
  47. The TweetsAbout module structure
  48. Using TwitterOAuth to authenticate our extension
  49. Developing the module
  50. Summary
  51. 7. Go Mobile with Magento 2.0!
  52. Adjusting the CompStore theme for mobile devices
  53. The Magento 2.0 responsive design
  54. The Magento UI
  55. Implementing a new CSS mixin media query
  56. Adjusting tweets about extensions for mobile devices
  57. Summary
  58. 8. Speeding up Your Magento 2.0
  59. Indexing and caching Magento
  60. Indexing and re-indexing data
  61. The Magento cron job
  62. Caching
  63. Fine-tuning the Magento hosting server
  64. Selecting the right Magento hosting service
  65. Apache web server deflation
  66. Enabling the expires header
  67. Minifying scripts
  68. Summary
  69. 9. Improving Your Magento Skills
  70. Magento knowledge center
  71. Improving your Magento skills
  72. Summary
  73. 2. Module 2
  74. 1. Magento 2 System Tools
  75. Installing Magento 2 sample data via GUI
  76. Installing Magento 2 sample data via the command line
  77. Managing Magento 2 indexes via the command line
  78. Managing Magento 2 cache via the command line
  79. Managing Magento 2 backup via the command line
  80. Managing Magento 2 set mode (MAGE_MODE)
  81. Transferring your Magento 1 database to Magento 2
  82. 2. Enabling Performance in Magento 2
  83. Configuring Redis for backend cache
  84. Configuring Memcached for session caching
  85. Configuring Varnish as the Full Page Cache
  86. Configuring Magento 2 with CloudFlare
  87. Configuring optimized images in Magento 2
  88. Configuring Magento 2 with HTTP/2
  89. Configuring Magento 2 performance testing
  90. 3. Creating Catalogs and Categories
  91. Create a Root Catalog
  92. Create subcategories
  93. Manage attribute sets
  94. Create products
  95. Manage products in a catalog grid
  96. 4. Managing Your Store
  97. Creating shipping and tax rules
  98. Managing customer groups
  99. Configuring inventories
  100. Configuring currency rates
  101. Managing advanced pricing
  102. 5. Creating Magento 2 Extensions – the Basics
  103. Initializing extension basics
  104. Working with database models
  105. Creating tables using setup scripts
  106. Creating a web route and controller to display data
  107. Creating system configuration fields
  108. Creating a backend data grid
  109. Creating a backend form to add/edit data
  110. 6. Creating Magento 2 Extensions – Advanced
  111. Using dependency injection to pass classes to your own class
  112. Modifying functions with the use of plugins – Interception
  113. Creating your own XML module configuration file
  114. Creating your own product type
  115. Working with service layers/contracts
  116. Creating a Magento CLI command option
  117. 3. Module 3
  118. 1. Planning for Magento
  119. Technical considerations
  120. Global-Website-Store methodology
  121. Planning for multiple stores
  122. Summary
  123. 2. Managing Products
  124. Managing products the customer focused way
  125. Creating products
  126. Managing inventory
  127. Pricing tools
  128. Autosettings
  129. Related products, up-sells, and cross-sells
  130. Importing products
  131. Summary
  132. 3. Designs and Themes
  133. The concept of theme inheritance
  134. Default installation of design packages and themes
  135. Installing third-party themes
  136. Inline translations
  137. Working with theme variants
  138. Customizing themes
  139. Customizing layouts
  140. Summary
  141. 4. Configuring to Sell
  142. Payment methods
  143. Shipping methods
  144. Managing taxes
  145. Transactional e-mails
  146. Summary
  147. 5. Managing Non-Product Content
  148. Summary
  149. 6. Marketing Tools
  150. Promotions
  151. Newsletters
  152. Using sitemaps
  153. Optimizing for search engines
  154. Summary
  155. 7. Extending Magento
  156. The new Magento module architecture
  157. Extending Magento functionality with Magento plugins
  158. Building your own extensions
  159. Summary
  160. 8. Optimizing Magento
  161. Indexing and caching
  162. Caching in Magento 2 – not just FPC
  163. Tuning your server for speed
  164. Summary
  165. 9. Advanced Techniques
  166. Version control
  167. Magento cron
  168. Backing up your database
  169. Upgrading Magento
  170. Summary
  171. 10. Pre-Launch Checklist
  172. System configurations
  173. Design configurations
  174. Search engine optimization
  175. Sales configurations
  176. Product configurations
  177. Maintenance configurations
  178. Summary
  179. Index

Version control

Version control is one of the most helpful and time-saving tools that can be used in support of software development. Even if you're only making small changes to the templates you're using, or adding modules without modifying the code inside of them, version control allows you to track changes that have been made and to evaluate code at any given point in time after the implementation. Even more importantly, it allows you to roll back the code to an earlier state, in cases where you're not quite sure what changes might have caused problems with the site.

At this point, the tool most widely used for version control by the development community is Git. Git is a system that was developed by Linus Torvalds (the originator of LINUX himself!) as a result of his frustration with existing tools. While it's beyond the scope of this book to go into much detail around what exactly it was that frustrated him, suffice to say that the changes he's made have positioned Git as the lingua franca for version control, and understanding its basics is a necessary endeavor if you want to do any development, or even just track changes to your system caused by upgrades.

Magento is a complicated system and even small changes can have a significant impact, causing errors that are obvious (site down) and some that are pernicious and creeping, such as the creation of bad data over time. Using a system to track all the changes that you and others have made to the system is a strongly recommended practice and will invariably, at some point, save you time, money, or both.

Let's start with a very basic prescription: installing the Git binary on your system and checking your current Magento site into a local repository. For the purposes of this example, we'll assume the use of OSX, although Git can be used for pretty much any modern operating system.

If you've installed the developer tools that come with OSX on your system, the Git binary will already be there. If you haven't and don't want to, you can download the Git binary from this link: https://git-scm.com/download/mac.

To make sure that Git has been installed on your system, open a terminal and type git –version. You should see the following output:

Version control

The next step you'll take will be to change to the document root of your Magento install. In this example, that's /Users/jbownds/websites/magento2. Once here, you can issue three simple commands to initialize the repository and check in the first version of your files. You'll start with git init ., followed by git add ., and finally git commit . –m "first checkin of files" (you can substitute another message here, if you like).

See the following screenshot for an example of what this will look like:

Version control

Once you've checked in the files, you'll see a flurry of messages indicating which files have been added, which looks something like this:

Version control

This indicates that the Git repository has been initialized locally and you're ready for the next step. As mentioned before, Git is a distributed version control system. That means it's easy (and a good idea) to store copies of it in different locations. There are many services that allow for this, but the most popular is probably GitHub. For this reason, we'll walk through the steps necessary to take the repository you've created and push it out to GitHub. Start by creating an account here: https://github.com/join:

Version control

Once you've created an account (there are both free and paid options here), you can create a new repository by clicking the appropriate button on the right gutter:

Version control

Click on the repository and there will be step-by-step instructions for pushing an existing repository from the command line:

Version control

Go back to the document root for the repository you created and paste these commands into the terminal. The first one should run without a problem, but the second one will probably run into some authentication issues, as in the following example:

Version control

As you can see in this example, the second command had issues. The specific error message is Fatal: could not read remote repository. Please make sure you have the correct access rights.

To address this, you'll need to add a public key for the user to GitHub, so GitHub recognizes the user trying to push this information into the remote repository. Don't worry - this sounds trickier than it is. All you need to do is type in ssh-keygen. You'll be prompted with several questions, all of which you can leave blank. At this point, you should have a generated public key for your user. You can view it by typing vi ~/.ssh/id_rsa.pub, and it'll look something like this (ignore the black arrow, this is just to blot out information in the private key).

Version control

Copy this key and head back to GitHub. Once there, you can add this key in the Settings area of your account:

Version control

Click New SSH key, provide a title, and paste the value you copied into the text area. Save this value:

Version control

Now, when you go back to the command line and try git push –u origin master command again, you'll see results like this:

Version control

Congratulations! You've created your first Git repository and pushed it out to GitHub.

Now, it's worth noting that there are a slew of very well-conceived visual tools that manage this process for you as well. It's beyond the scope of this text to evaluate these tools but it's worth mentioning a couple.

GitHub itself has a free desktop tool you can download and use, and it's quite handy for a visual representation of what's going on. The other tool we've seen used predominately is Tower. Tower can be obtained by visiting their website at https://www.git-tower.com/.While there is cost associated with the use of this tool (after a free trial), if you prefer a visual representation of what's happening with version control, this option may be more attractive to you.

Version control