Forums / Install & configuration / SSH Requirement

SSH Requirement

Author Message

Tim Dickinson

Monday 26 May 2008 9:05:53 pm

I haven't been around these parts in a while, and that was because I was busy running my eZpublish sites rather than making changes.

However, my situation has now changed with my host no longer offering SSH access to customers.

So my question is - is SSH access still a requirement of running/upgrading/installing eZpublish? Are there any work arounds? - I couldn't find anything useful/up-to-date with a search so any info would be useful.

Thanks

-Tim

http://www.AdBalance.com - Ad network news and reviews
http://www.DevPublisher.com - Website publisher guides, tools and news
http://www.AudioMelody.com - Make better music

Maxime Thomas

Monday 26 May 2008 11:52:40 pm

Hi Tim,

I believe that SSH is a kind of freedom that you won't do without it once you have tasted it.
It has a real singification if you get root access on the host :
- you can change the apache settings
- you can clear the cache in command line
- you can change the rights on some files

It represents no intersests to get a ssh access to a host you can't choose what packages are installed in.

It is still my opinion. :-D

Maxime Thomas
maxime.thomas@wascou.org | www.wascou.org | http://twitter.com/wascou

Company Blog : http://www.wascou.org/eng/Company/Blog
Technical Blog : http://share.ez.no/blogs/maxime-thomas

Tim Dickinson

Tuesday 27 May 2008 6:50:50 am

Thanks for the reply,

I agree that it adds an ease to doing things, but these sites are not being actively developed but more content being continually added so I don't need to do this stuff that often.

I have CPanel as a control panel, and can use cron jobs - any way I can run the PHP scripts through this (ie. set them 2 minutes into the future to run etc)?

The question is though - is SSH access a requirement for installing/running/upgrading an eZpublish site, or just a luxury that saves time and makes life easier?

Thanks

-Tim

http://www.AdBalance.com - Ad network news and reviews
http://www.DevPublisher.com - Website publisher guides, tools and news
http://www.AudioMelody.com - Make better music

Björn Dieding@xrow.de

Tuesday 27 May 2008 8:06:45 am

> is SSH access still a requirement of running/upgrading/installing eZpublish?

yes it is.

> Are there any work arounds?

Yes there are if you only have little data, but they are to costy to maintain. You would need to hack eZScript. This is not recommended at all. I would rather say there is not a workaround.

Recommendation:
Move to a host with SSH.

Looking for a new job? http://www.xrow.com/xrow-GmbH/Jobs
Looking for hosting? http://hostingezpublish.com
-----------------------------------------------------------------------------
GMT +01:00 Hannover, Germany
Web: http://www.xrow.com/

Gaetano Giunta

Tuesday 27 May 2008 2:07:36 pm

Hey, that might make an interesting feature request.
Or a nice extension. Maybe it even exists already?

Worst-case scenario is hard-to-solve chicken-and-egg situations, but for general usage, we could say that if user has access to cron, he can do it:
- minor (?) hacks to ezscript so that it can be run from "within" runcronjobs
- add a table used to hold scripts to be run
- add admin interface to fill the table
- schedule at 'frequent' the cronjob that goes read that table, executes the scripts and removes them from the table
Not really realtime, but it could be good for most of the long tasks that need to be started via cli...

Principal Consultant International Business
Member of the Community Project Board

Piotrek Karaś

Tuesday 27 May 2008 8:30:47 pm

One (freebsd-based) hosting platform that we use to host small-scaled projects:
a) has no CLI
b) has script-like CRON (read: PHP-based, with all the PHP restrictions, ie.: timeouts...)

When we stood the first steps with eZ, it was very challenging. Luckily, PHP's system() function makes it possible to perform all the basic maintenance tasks and also we were able to make CRON run, anyways.

Still, this is far from perfect, especially when one knows the freedom and security that CLI gives.

--
Company: mediaSELF Sp. z o.o., http://www.mediaself.pl
eZ references: http://ez.no/partners/worldwide_partners/mediaself
eZ certified developer: http://ez.no/certification/verify/272585
eZ blog: http://ez.ryba.eu

Maxime Thomas

Tuesday 27 May 2008 11:14:33 pm

Hi Gaetano,

I'm interested on your extension idea but I've got a kind of block with the concept of merging contexts : you would like to set or run commands that have to be executed in command line via a web interface ? So, how do you manage return on errors ?
Another point, if you go further, you lay implement the cron run on demand, by just clicking the button in the back office. But, if the cron spends so much time that it reachs the timeout limit, what happends ? We loose the control of the php script ?

Maxime Thomas
maxime.thomas@wascou.org | www.wascou.org | http://twitter.com/wascou

Company Blog : http://www.wascou.org/eng/Company/Blog
Technical Blog : http://share.ez.no/blogs/maxime-thomas

Gaetano Giunta

Wednesday 28 May 2008 12:59:47 am

What I was thinking about is more or less like this: runcronjobs.php is not actually invoked directly by the ui. Just a new task added to the list of stuff to be executed on the next cron run. When the cron job is run (by the system scheduler), runcronjobs.php runs the php code (we can call it "taskrunner") that will fetch the task and execute it.

There is little problem with timeouts, as the runcronjobs script already allows himself 24h to run. Otoh it is mutex-protected, which means only a runcronjobs script can be running at a time. If you have a very long executing task, the standard tasks executed by the frequent cronjob might be delayed.

About error/output reporting: the taskrunner code can set a flag in the task table so that currently executing tasks can be identified as such. Then, when the task terminates, the task output is also added to the table.

Using the 'system' php call this can be done in a very easy way, but I wonder if in some hosting environments system is disabled. Otherwise php output buffering is your friend

Principal Consultant International Business
Member of the Community Project Board

Maxime Thomas

Thursday 29 May 2008 12:18:19 am

I was thinking to another thing too, is it possible to make a daemon in php ? It can be solution for long processes that have to be run in background...
With a gui to monitor it...

I'm dreaming :-D

Maxime Thomas
maxime.thomas@wascou.org | www.wascou.org | http://twitter.com/wascou

Company Blog : http://www.wascou.org/eng/Company/Blog
Technical Blog : http://share.ez.no/blogs/maxime-thomas

eZ debug

Timing: Jan 18 2025 10:39:08
Script start
Timing: Jan 18 2025 10:39:08
Module start 'content'
Timing: Jan 18 2025 10:39:09
Module end 'content'
Timing: Jan 18 2025 10:39:09
Script end

Main resources:

Total runtime0.8864 sec
Peak memory usage4,096.0000 KB
Database Queries218

Timing points:

CheckpointStart (sec)Duration (sec)Memory at start (KB)Memory used (KB)
Script start 0.00000.0104 588.8359180.8438
Module start 'content' 0.01040.7260 769.6797762.4531
Module end 'content' 0.73630.1500 1,532.1328348.4453
Script end 0.8863  1,880.5781 

Time accumulators:

 Accumulator Duration (sec) Duration (%) Count Average (sec)
Ini load
Load cache0.00400.4475210.0002
Check MTime0.00150.1712210.0001
Mysql Total
Database connection0.00120.131610.0012
Mysqli_queries0.775487.48532180.0036
Looping result0.00280.31042160.0000
Template Total0.849095.820.4245
Template load0.00200.227320.0010
Template processing0.847095.555320.4235
Template load and register function0.00010.016010.0001
states
state_id_array0.00200.226410.0020
state_identifier_array0.00110.126020.0006
Override
Cache load0.00190.2094680.0000
Sytem overhead
Fetch class attribute can translate value0.00120.137560.0002
Fetch class attribute name0.00130.1487140.0001
XML
Image XML parsing0.00310.354860.0005
class_abstraction
Instantiating content class attribute0.00000.0040180.0000
General
dbfile0.00350.3939520.0001
String conversion0.00000.000630.0000
Note: percentages do not add up to 100% because some accumulators overlap

CSS/JS files loaded with "ezjscPacker" during request:

CacheTypePacklevelSourceFiles
CSS0extension/community/design/community/stylesheets/ext/jquery.autocomplete.css
extension/community_design/design/suncana/stylesheets/scrollbars.css
extension/community_design/design/suncana/stylesheets/tabs.css
extension/community_design/design/suncana/stylesheets/roadmap.css
extension/community_design/design/suncana/stylesheets/content.css
extension/community_design/design/suncana/stylesheets/star-rating.css
extension/community_design/design/suncana/stylesheets/syntax_and_custom_tags.css
extension/community_design/design/suncana/stylesheets/buttons.css
extension/community_design/design/suncana/stylesheets/tweetbox.css
extension/community_design/design/suncana/stylesheets/jquery.fancybox-1.3.4.css
extension/bcsmoothgallery/design/standard/stylesheets/magnific-popup.css
extension/sevenx/design/simple/stylesheets/star_rating.css
extension/sevenx/design/simple/stylesheets/libs/fontawesome/css/all.min.css
extension/sevenx/design/simple/stylesheets/main.v02.css
extension/sevenx/design/simple/stylesheets/main.v02.res.css
JS0extension/ezjscore/design/standard/lib/yui/3.17.2/build/yui/yui-min.js
extension/ezjscore/design/standard/javascript/jquery-3.7.0.min.js
extension/community_design/design/suncana/javascript/jquery.ui.core.min.js
extension/community_design/design/suncana/javascript/jquery.ui.widget.min.js
extension/community_design/design/suncana/javascript/jquery.easing.1.3.js
extension/community_design/design/suncana/javascript/jquery.ui.tabs.js
extension/community_design/design/suncana/javascript/jquery.hoverIntent.min.js
extension/community_design/design/suncana/javascript/jquery.popmenu.js
extension/community_design/design/suncana/javascript/jScrollPane.js
extension/community_design/design/suncana/javascript/jquery.mousewheel.js
extension/community_design/design/suncana/javascript/jquery.cycle.all.js
extension/sevenx/design/simple/javascript/jquery.scrollTo.js
extension/community_design/design/suncana/javascript/jquery.cookie.js
extension/community_design/design/suncana/javascript/ezstarrating_jquery.js
extension/community_design/design/suncana/javascript/jquery.initboxes.js
extension/community_design/design/suncana/javascript/app.js
extension/community_design/design/suncana/javascript/twitterwidget.js
extension/community_design/design/suncana/javascript/community.js
extension/community_design/design/suncana/javascript/roadmap.js
extension/community_design/design/suncana/javascript/ez.js
extension/community_design/design/suncana/javascript/ezshareevents.js
extension/sevenx/design/simple/javascript/main.js

Templates used to render the page:

UsageRequested templateTemplateTemplate loadedEditOverride
1node/view/full.tplfull/forum_topic.tplextension/sevenx/design/simple/override/templates/full/forum_topic.tplEdit templateOverride template
9content/datatype/view/ezimage.tpl<No override>extension/sevenx/design/simple/templates/content/datatype/view/ezimage.tplEdit templateOverride template
9content/datatype/view/ezxmltext.tpl<No override>extension/community_design/design/suncana/templates/content/datatype/view/ezxmltext.tplEdit templateOverride template
13content/datatype/view/ezxmltags/paragraph.tpl<No override>extension/ezwebin/design/ezwebin/templates/content/datatype/view/ezxmltags/paragraph.tplEdit templateOverride template
7content/datatype/view/ezxmltags/line.tpl<No override>design/standard/templates/content/datatype/view/ezxmltags/line.tplEdit templateOverride template
1pagelayout.tpl<No override>extension/sevenx/design/simple/templates/pagelayout.tplEdit templateOverride template
 Number of times templates used: 40
 Number of unique templates used: 6

Time used to render debug report: 0.0002 secs