Tutor Users' Group
- 1 Charter
- 2 Recordings and Transcripts
- 3 Agenda and Notes
- 3.1 2024-11-18
- 3.2 2024-11-04
- 3.3 2024-10-21
- 3.4 2024-09-23
- 3.5 2024-08-26
- 3.6 2024-08-12
- 3.7 2024-07-29
- 3.8 2024-07-15
- 3.9 2024-06-03
- 3.10 2024-05-20
- 3.11 2024-05-06
- 3.12 2024-04-22
- 3.13 2024-04-08
- 3.14 2024-03-25
- 4 Older Notes
Charter
It’s become clear that there is an acute need to support new Tutor users and plugin developers. It’s also clear that Tutor maintainers benefit from hearing feedback from people who are using the tool.
Please join our users’ group for sharing help, tips, and feedback on using Tutor and developing Tutor plugins. Bring your questions, and get ready for some live debugging! Expert or newbie, all are welcome.
Announcements will be posted to Slack in #tutor-maintenance
Recordings and Transcripts
All public Working Group meetings follow the Recording Policy for Open edX Meetings
https://drive.google.com/drive/folders/1hdlItbQ6RK8iHeOZXahpo_vIo5offr_h
Agenda and Notes
We meet every other week. Our schedule and video conferencing link is on the Working Group Calendar. The meeting is usually hosted by @Kyle McCormick .
You can add topics below ahead of time, or add them during the meeting.
2024-11-18
2024-11-04
WordPress plugin for commerce
Speed of change to microfrontends makes it difficult to want to contribute
robots.txt for most MFEs
Caddyfile could add a robots.txt like this to the MFE container, with varying restrictions based on the MFEs within the container:
# robots.txt {% for app in MFE_APPS %} {% if app['no-crawl'] % } User-agent: * Disallow: /{app} {% edif % } {% endfor %} User-agent: * Disallow: /learning/course/*/progress # Don't crawl learner progress pages
2024-10-21
(if you’re watching the recording, jump to ~0:13 for the beginning of conversation)
Kyle/Hina: Tour of GitHub - overhangio/tutor-indigo: An elegant, customizable theme for Open edX
Emad:Superset does not support Arabic language -RTL- layout · Issue #25258 · apache/superset
Max: Mini update on RG’s use of verdaccio to mitigate the fact that npm-install is regularly timing out / getting rate-limited
2024-09-23
Improve Tutor's shell autocompletion response time · Issue #26 · openedx/wg-devops
AI
perf: don't unneccessarily rebuild dev assets by kdmccormick · Pull Request #39 · kdmccormick/tutor
Kyle will work on this in November
Database migrations are slow
An older doc on this: Everything About Database Migrations | Comment
2024-08-26
tutor-legacy-assets idea
too many MFEs
agreed
we’ll use existing MFEs for new pages
tutor-contrib-verdaccio update: not conclusive
ubuntu upgrade – maintainers will need to update their dockerfiles
note: open edx upstream will just test on ubuntu-latest going forward
2024-08-12
Follow-up on tutor-contrib-verdaccio.
Official plugin? Core? Not ready? Need more time to evaluate?
Test Verdaccio plugin for build improvements · Issue #220 · overhangio/tutor-mfe
The plugin doesn’t work for Docker Desktop but only for Orbstack - need to check the docker.internal for docker desktop
We will continue the conversation in the discuss and tutor-mfe issue
We tutor maintainers should keep an eye on DEPR tickets and make sure plugins get deprecated if the upstream code gets deprecated
2024-07-29
Moises: Dockerfile reference I wanted to use the
RUN --mount=type=ssh
instruction to install private packages. This command needs an additional flag to the build command that I can add via theDOCKER_BUILD_COMMAND
filter. The problem is that the--ssh=default=$SSH_AUTH_SOCK
flag gets escaped by shlex. As a workaround is possible to useos.environ.get("SSH_AUTH_SOCK")
but some people may not want to print those values to the stdout.what type of packages?
Zameel: Installing npm packages from a private github repo
cloned with personal access token, installed locally
didn’t need to use
--mount=type=ssh
Dawoud: is it
--ssh=default=$SSH_AUTH_SOCK
or--ssh default=$SSH_AUTH_SOCK
?Kyle:
--ssh=default=$SSH_AUTH_SOCK
– what is getting escaped?Max: we are also interested in this answer
@Moisés González do you have a POC to try?
RG is interested in helping to implement or test the proposal
In our non-tutor deployments we extensively used SSH key for private repos cloning
Max’s verdaccio plugin: Local NPM registry for MFE builds
Issues
doesn’t work without
host.docker.internal
hostname
Important insight- timing
very good time for low parallelism (max 2) – 12min
worst time for high parallellism (no max) – 27min
Regis
Caching npm deps – good.
Regis runs verdaccio on a remote server.
Getting issues with timeouts/connection.
not sure if connection issue is b/w verdaccio and tutor or verdaccio and npm
Running a container before a build – not supported in tutor naturally
Doesn’t make sense to have separate verdaccios for nightly vs master
Decouple launching verdaccio instance vs configuring NPM_REGISTRY
starting verdaccio could be managed by docker, not docker-compose
tutor local do verdaccio-start
?
Max - similarly, don’t like idea of having a Tutor service that’s not truly a tutor service
Max - why a separate machine for verdaccio?
regis - didn’t know about
host.docker.internal
Max - it doesn’t seem to be resource intensive for his machine
Max’s coworker disagrees
Regis - it uses …. MB memory and … MB disk space. Not very intensive in either case
What does the api look like?
Regis:
tutor local do verdaccio start
would start verdaccio. would print an instruction to run
tutor config save --set NPM_REGISTRY=host.docker.internal:$PORT
Kyle:
tutor verdaccio start
, same as aboveMax:
tutor npm-mirror start
, same as aboveMax: plugin or core?
Regis: try out a couple weeks , and see whether to add it to core?
Kyle: worried about resource usage depending on different machines, want it to be optional
Max: parallellism, why does unbounded parallelism slow it down?
Zameel - non-latin languages and mysql 5.7
course outline was not getting saved to mysql
mysql was using latin-1 instead of utf-8
Kyle: is Palm upgrade, running RDBMS in Tutor, MySQL vs. MariaDB, utf8 vs. utf8mb4 relevant?
Zameel: https://discuss.openedx.org/t/load-missing-lesson-information-in-mysql-table/10034/11
Regis: In Redwood (v18), default collation changed from utf8 to utf8mb4
Zameel: could we have tutor docs warning about this?
Zameel: to fix, we made a mysql backup, changed encoding from latin-1 to utf-8. encoding, not character set.
Dawoud: when tutor configures mysql, we pass in args to ensure it’s utf8: https://github.com/overhangio/tutor/blob/palm/tutor/templates/local/docker-compose.yml#L43 . But these are not passed to the managed service.
Zameel: mysql 5.7 by default uses
Kyle: “bare metal” edx-platform docs: https://github.com/openedx/edx-platform?tab=readme-ov-file#bare-metal-advanced
a note there that flags must be passed in to configure mysql to use utf-8 and utf8mb4 , rather than latin-1
not neccessary for mysql 8, though.
Nihad: https://discuss.openedx.org/t/unable-to-import-open-edx-demo-course-in-redwood-release/13455 ,
2024-07-15
Glib: Tutor Plugins -
Discussing with marketing wg the idea of having a marketplace catalog
Making plugins available for operators
Particularly plugins with one-click installation process
^ … that’s tutor plugins!
particularly plugins in the tutor index
Question: Many plugins require post-actiosn
Rebuild image
Run init
Configure something
Idea: a flag that runs all those necessary extra steps automatically, to enable the one-click installation
Idea: always rebuild and run init
Max mentioned that he wouldn’t want Tutor to automatically run any actions, since many operators have customizations that make it so they wouldn’t want to do every step necessarily
in other words – some operators will want to be able to run steps manually, others will want it all to happen automagically
Dave: Could Tutor have a GUI interface ?
Dawoud: This has been discussed, there is interest
there is the webui plugin - https://github.com/overhangio/tutor-webui
but it’s the same CLI, served for a web browser to access
Kyle: What is the UI for the marketplace to be?
Glib: First phase, just a catalog
Description, installation instructions
Manually maintained
Glib: Integration into tutor would be a second phase
Dawoud: We are already re-building and re-initting when we run
tutor ... launch
, so not sure if we want a flag on the plugin commandGhassan: we also have
tutor ... do init --limit=pluginname
Glib: We’re thinking about command that must be run after plugin is installed and enabled
Example: Jupyter pluginhttps://edly.io/tutor/jupyter-notebooks-plugin/
Idea:
tutor plugins install jupyter --enable --rebuild --run-init --configure JUPYTER_VERSION=5
Glib: Currently it requires several commands
tutor plugins install blah tutor plugins enable blah tutor config save --set ... tutor images rebuild openedx tutor local do init --limit=blah
One option:
A compromise:
Moises: If launch had a flag to rebuild, would that cut it?
Dawoud: install can take multiple plugins
Kyle/Glib: --enable would enable all provided commands
Glib: When you’re installing a plugin from outside the indexes, it’s
pip install -e .
, right?`tutor plugins install ./path/to/mylocal/plugin`
this works
$(tutor plugins printroot)/myplugin
putting plugins here will install them automatically
Three changes, Kyle will make issues, looking for volunteers to implement
An
--enable
flag ontutor plugins install
A
--configure
flag ontutor plugins install
, just liketutor config save --set ...
A
--limit-init
flag ontutor ... launch
Moises: Build time for installing Python packages: https://github.com/overhangio/tutor/pull/1088
Glib: Brian M says he was experimenting with pip-tools replacement in rust, but hit an issue where it doesn’t support egg files
Dawoud:
Michael: being able to limit init for launch might solve another problem: Shared mysql server, don’t want to provide admin user or password, so mysql init fails
2024-06-03
MFE build time (below)
Configuring open edx services with tutor
Moises and Maksim work on large instances group
Some of tutor’s default were meant to simplify setup
For large instances, they need to undo tutor’s defaults
example: celery queues
tutor uses one celery queue
at scale, the queue can fill up
using patches, large instances has been undoing tutor’s configuration changes
edx-platform is complex to follow, with all the indirection
related: OEP-45 simplification
could be better to have a blank slate
edunext had to replicate ansible installation settings, using tutor
they are using settings patches
yaml settings patch
common settings
production patches
some files don’t have patches
Having plugins expose configuration interfaces
tutor-contrib-pod-autoscaling
rather than add more config settings, the plugin
2024-05-20
MFE build time
1hr+ to build MFEs
Number of MFEs has not changed since Quince – 10 (https://github.com/overhangio/openedx-release-demo/blob/master/.github/workflows/deploy.yml#L101 )
Custom npm registries
Local deployment of an npm registry
vs. shared npm registry
devstack had devpi for python reqs
devpi is pretty easy to set up
install vs build - which is the problem?
both
building all MFEs (except Learner Dash) without cache on AWS spot fleet m5.xlarge
parallelism=4
Duration: 43 minutes 4 seconds
Max number of simultaneous connections to npm registry by IP address
why does the network connection break when we have too much parallelism in the build?
this seems different than the npm connection limitation. seems that the host’s network connection is failing
saturation of bandwidth?
to build mfes in sandbox, had to explicitly set max_parallelism=2
Solutions
Sharing dependencies across MFEs
“No New MFEs”
@Kyle McCormick
Remote registry
Axim-provided registry? network of registries, different providers in different regions
@Kyle McCormick
Local registry
This can definitely have multiple versions
@Maksim Sokolskiy
Local cache. Two potential issues:
1. ensure that it’s actually caching anything at all:https://discuss.openedx.org/t/npm-clean-install-in-mounted-directories-sh-super-slow-on-tutor-nightly-dev-with-mounted-edx-platform/12761/3
2. version conflicts across MFEs may invalidate a shared cache
@Dawoud Sheraz
Other solutions (not currently following up on)
Pre-built image with some deps
Max has tried this
Install one mfe’s deps using previous mfe as a base
Used pnpm – can handle multiple different versions of package
pnpm didn’t work out of the box
pnpm , workspace for each mfe
2024-05-06
…
2024-04-22
Present: several people
2024-04-08
Meeting link: https://meet.google.com/rhs-veey-rrp
Present: @Chintan Joshi , @Danyal Faheem, @Dave Ormsbee (Axim) , @Dawoud Sheraz , @Deimer Morales ,@Maksim Sokolski, @Maria Grimaldi, Qasim Gulzar , @Régis Behmo
Integrate Tutor with IntelliJ IDEA/Pycharm (by Qasim Gulzar@edly)
Recording: https://drive.google.com/file/d/13yNuZktzCOIg6_Hym9_peZmD-RC-CgD_/view
The tutorial instructions will be published soon-ish in a dedicated space.
In the meantime, we can reproduce the instructions with the video recording.
Instructions are still hackish and a little brittle, we can definitely work to improve them.
How to track the eclipse with Tutor (by @Régis Behmo if time permits) (it did not)
Notes:
MongoDb 7 upgrade: scheduled for Redwood
utf8mb3 upgrade. We reached the following decisions for Redwood:
upgrade the connection string and the database default charset to utf8mb4 for all platforms
For existing platforms, upgrade the default database charset (with
ALTER DATABASE databasename CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;
).For existing platforms, convert tables in a conservative manner, using instructions similar to:
ALTER TABLE tablename CONVERT TO CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;
. The list of candidate tables is available here.Implementation of these decisions can be followed in this GitHub issue: https://github.com/overhangio/tutor/issues/938
MySQL high memory issue on Arch Linux: https://github.com/docker-library/mysql/issues/579#issuecomment-1075119349
It was suggested that Arch users manually create a docker-compose.override.yml file.
We should update the troubleshooting instructions for Arch Linux users. @Deimer Morales can you please open a pull request to update the Tutor docs?
2024-03-25
Auto-mounted directories
Can we add mount keywords in our own plugin? → yes, or open a PR to upstream plugin
Do we list the keywords anywhere? example,
platform-plugin-
The exact list is not documented anywhere
MFE mounts
Tried to mount custom mfe – couldn’t do it
used command line mount
did not see the mfe on the port
seems like folder was mounted, but MFE filter wasn’t added to, so the tutor-mfe plugin didn’t know to build/run the mfe
How Zach did it:
Let’s talk about MFE image building… why we (usually) don’t need to re-build, and figuring out this Docker build cache madness. (@Régis Behmo )
Theoretically, rebuild should only happen if (1) we change an MFE and (2) we’re pushing it to production
Errors when installing node_modules
npm error, socket reset, registry hangup
Docker build cache size needs to be set large enough so that it doesn’t get garbage collected between mfe builds
need to change a config item in $HOME/.docker/daemon.json
If you think you rebuild too often, try upping docker build cache max size
Talked about https://github.com/kdmccormick/tutor/pull/34 - kyle will continue to work on
Production vs dev flow in docs - docs nudge you towards production flow
Remote image building - anyone?
edunext has - they build tutor-nightly images on an ec2 instance
20-30 minutes for uncustomized mfe image
custom multiarch builder - regis builds macos images even though he doesn’t have a mac
Older Notes
Paste old notes here.